656

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

很多时候,我只想将某些内容附加到/etc/hosts或类似的文件中,但最终无法做到,因为这两者>都是>>不允许的,即使使用 root 也是如此。

有没有办法让这项工作无需进入根目录susudo su

4

15 回答 15

979

使用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工作方式类似>>并将写入文件末尾。

于 2009-02-15T12:34:20.173 回答
338

问题是 shell 确实输出重定向,而不是 sudo 或 echo,所以这是作为您的普通用户完成的。

试试下面的代码片段:

sudo sh -c "echo 'something' >> /etc/privilegedfile"
于 2008-09-17T16:11:30.177 回答
37

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

使用这样的东西,也许:

sudo sh -c "echo 'something' >> /etc/privilegedFile"
于 2008-09-17T16:13:12.093 回答
18
sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"
于 2008-09-17T16:11:23.140 回答
15

正在做

sudo sh -c "echo >> somefile"

应该管用。问题是 > 和 >> 由您的 shell 处理,而不是由“sudoed”命令处理,因此权限是您的,而不是您“sudo”进入的用户的权限。

于 2008-09-17T16:14:45.940 回答
11

我会注意到,出于好奇,你也可以引用一个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"
于 2014-02-13T20:10:21.420 回答
9

在 bash 中,您可以tee结合使用> /dev/null来保持标准输出干净。

 echo "# comment" |  sudo tee -a /etc/hosts > /dev/null
于 2014-03-19T20:53:04.277 回答
6

一些用户在使用多行时不知道解决方案。

sudo tee -a  /path/file/to/create_with_text > /dev/null <<EOT 
line 1
line 2
line 3
EOT
于 2020-09-24T14:41:48.923 回答
4

使用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
}
于 2014-09-24T17:50:33.143 回答
2

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

例如,将带有 $NEW_IP 的 $NEW_HOST 添加到 /etc/hosts:

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

sed 选项解释:

  • -i就地
  • $最后一行
  • 一个用于追加
于 2018-04-24T13:43:26.313 回答
2

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

echo 'Add this line' | sudo sponge -a privfile
于 2018-06-27T00:41:18.673 回答
0

回声“你好世界” | (sudo tee -a /etc/apt/sources.list)

于 2018-10-18T05:10:33.613 回答
0

怎么样:
回显文本 | 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"
用单行文档消除了回声

于 2019-08-23T22:55:02.280 回答
-1

这对我有用:原始命令

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

工作指挥

echo "export CATALINA_HOME="/opt/tomcat9"" |sudo tee /etc/environment
于 2017-09-16T06:50:35.603 回答
-6

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

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

像这样的东西适合你吗?

于 2017-01-21T23:05:37.290 回答