sudo echo“something”>> / etc / privilegedFile不起作用

bash shell scripting permissions sudo

176417 观看

14回复

9666 作者的声誉

对于Linux中的sudo权限,这是一个非常简单的问题,至少看起来应该是这样。

有很多的时候,我只是想将一些东西附加到/etc/hosts或类似的文件,但最终没有能够因为两者>>>不准,甚至有根。

有没有必要让这项工作无需susudo su进入root?

作者: David 的来源 发布者: 2008 年 9 月 17 日

回应 (14)


17

211601 作者的声誉

sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"
作者: Vinko Vrsalovic 发布者: 17.09.2008 04:11

298

3897 作者的声誉

问题是shell确实输出了重定向,而不是sudo或echo,因此这是以普通用户身份完成的。

请尝试以下代码段:

sudo sh -c "echo 'something' >> /etc/privilegedfile"
作者: Matt P 发布者: 17.09.2008 04:11

31

389 作者的声誉

问题是它是你的shell处理重定向; 它试图用您的权限打开文件,而不是在sudo下运行的进程。

使用这样的东西,也许:

sudo sh -c "echo 'something' >> /etc/privilegedFile"
作者: Incident 发布者: 17.09.2008 04:13

13

6488 作者的声誉

sudo sh -c "echo >> somefile"

应该管用。问题是>和>>由shell处理,而不是由“sudoed”命令处理,因此权限是你的权限,而不是你正在“sudoing”的用户权限。

作者: agnul 发布者: 17.09.2008 04:14

782

11088 作者的声誉

决定

使用tee --appendtee -a

echo 'deb blah ... blah' | sudo tee -a /etc/apt/sources.list

请务必避免引号内的引号。

要避免将数据打印回控制台,请将输出重定向到/ dev / null。

echo 'deb blah ... blah' | sudo tee -a /etc/apt/sources.list > /dev/null

记住(-a/ --append)标志!只是tee工作>,并将覆盖您的文件。tee -a类似于>>并将在文件末尾写入。

作者: Yoo 发布者: 15.02.2009 12:34

9

7405 作者的声誉

我会注意到,好奇的是,你也可以引用一个heredoc(对于大块):

sudo bash -c "cat <<EOIPFW >> /etc/ipfw.conf
<?xml version=\"1.0\" encoding=\"UTF-8\"?>

<plist version=\"1.0\">
  <dict>
    <key>Label</key>
    <string>com.company.ipfw</string>
    <key>Program</key>
    <string>/sbin/ipfw</string>
    <key>ProgramArguments</key>
    <array>
      <string>/sbin/ipfw</string>
      <string>-q</string>
      <string>/etc/ipfw.conf</string>
    </array>
    <key>RunAtLoad</key>
    <true></true>
  </dict>
</plist>
EOIPFW"
作者: msanford 发布者: 13.02.2014 08:10

8

1537 作者的声誉

在bash中,你可以tee结合使用> /dev/null来保持标准清洁。

 echo "# comment" |  sudo tee -a /etc/hosts > /dev/null
作者: Vytenis Bivainis 发布者: 19.03.2014 08:53

4

651 作者的声誉

使用Yoo的答案,把它放在你的~/.bashrc

sudoe() {
    [[ "$#" -ne 2 ]] && echo "Usage: sudoe <text> <file>" && return 1
    echo "$1" | sudo tee --append "$2" > /dev/null
}

现在你可以跑了 sudoe 'deb blah # blah' /etc/apt/sources.list


编辑:

一个更完整的版本,允许您管道输入或从文件重定向,并包括一个-a关闭附加的开关(默认情况下打开):

sudoe() {
  if ([[ "$1" == "-a" ]] || [[ "$1" == "--no-append" ]]); then
    shift &>/dev/null || local failed=1
  else
    local append="--append"
  fi

  while [[ $failed -ne 1 ]]; do
    if [[ -t 0 ]]; then
      text="$1"; shift &>/dev/null || break
    else
      text="$(cat <&0)"
    fi

    [[ -z "$1" ]] && break
    echo "$text" | sudo tee $append "$1" >/dev/null; return $?
  done

  echo "Usage: $0 [-a|--no-append] [text] <file>"; return 1
}
作者: hololeap 发布者: 24.09.2014 05:50

-6

1 作者的声誉

您可以更改文件的所有权,然后在使用cat >>后追加更改吗?

sudo chown youruser /etc/hosts  
sudo cat /downloaded/hostsadditions >> /etc/hosts  
sudo chown root /etc/hosts  

这样的东西对你有用吗?

作者: pixistix 发布者: 21.01.2017 11:05

-1

90 作者的声誉

这对我有用:原始命令

echo "export CATALINA_HOME="/opt/tomcat9"" >> /etc/environment

工作指挥

echo "export CATALINA_HOME="/opt/tomcat9"" |sudo tee /etc/environment
作者: f.a.abadi 发布者: 16.09.2017 06:50

0

6814 作者的声誉

通过使用sed -i$ a,您可以在最后一行之后追加包含变量和特殊字符的文本。

例如,将$ NEW_HOST与$ NEW_IP一起添加到/ etc / hosts:

sudo sed -i "\$ a $NEW_IP\t\t$NEW_HOST.domain.local\t$NEW_HOST" /etc/hosts

sed选项解释:

  • -i for in place
  • 最后一行的 $
  • a追加
作者: Noam Manos 发布者: 24.04.2018 01:43

2

53116 作者的声誉

你也可以spongemoreutils包中使用,不需要重定向输出(即没有tee噪音隐藏):

echo 'Add this line' | sudo sponge -a privfile
作者: Michael Goldshteyn 发布者: 27.06.2018 12:41

0

1 作者的声誉

echo'Hello World'| (sudo tee -a /etc/apt/sources.list)

作者: Sudev Shetty 发布者: 18.10.2018 05:10

0

101 作者的声誉

怎么样:echo text | sudo dd status = none of = privilegedfile我想更改/ proc / sys / net / ipv4 / tcp_rmem。我做了:sudo dd status = none of = / proc / sys / net / ipv4 / tcp_rmem <<<“4096 131072 1024000”用单行文档消除回声

作者: Marcelo Pacheco 发布者: 23.08.2019 10:55
32x32