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

时间:2008-09-17 16:09:01

标签: bash shell scripting permissions sudo

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

很多时候,我只想向/etc/hosts或类似文件添加内容,但由于>>>都不允许,最终无法添加内容,甚至用root。

是否可以在不必susudo su根目录的情况下完成此工作?

15 个答案:

答案 0 :(得分:760)

使用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

答案 1 :(得分:294)

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

请尝试以下代码段:

sudo sh -c "echo 'something' >> /etc/privilegedfile"

答案 2 :(得分:31)

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

使用这样的东西,或许:

sudo sh -c "echo 'something' >> /etc/privilegedFile"

答案 3 :(得分:17)

sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"

答案 4 :(得分:13)

sudo sh -c "echo >> somefile"

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

答案 5 :(得分:9)

我会注意到,好奇的是,你也可以引用一个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"

答案 6 :(得分:8)

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

 echo "# comment" |  sudo tee -a /etc/hosts > /dev/null

答案 7 :(得分:4)

使用Yoo's answer,将其放在~/.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
}

答案 8 :(得分:2)

您还可以使用sponge包中的moreutils,而无需重定向输出(即,无需隐藏tee杂讯):

echo 'Add this line' | sudo sponge -a privfile

答案 9 :(得分:1)

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

sudo tee -a  /path/file/to/create_with_text > /dev/null <<EOT 
line 1
line 2
line 3
EOT

答案 10 :(得分:0)

回声“ Hello World” | (sudo tee -a /etc/apt/sources.list)

答案 11 :(得分: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”
通过单行文档消除回声

答案 12 :(得分:-1)

这对我有用: 原始命令

<div id="top-btn" class="flex fade-in">
  <a href=""><i> link </i></a>
  <div id="top-btn-BG">ghjghjg</div>
</div>

工作指令

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

答案 13 :(得分:-1)

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 最后一行
  • $
  • 以追加

答案 14 :(得分:-6)

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

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

这样的工作对你有用吗?