sudo echo"something">>/etc/privilegedFile不起作用......有替代方案吗?

Dav*_*vid 555 permissions bash shell scripting sudo

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

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

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

Yoo*_*Yoo 806

使用tee --appendtee -a.

echo 'deb blah ... blah' | sudo tee -a /etc/apt/sources.list
Run Code Online (Sandbox Code Playgroud)

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

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

echo 'deb blah ... blah' | sudo tee -a /etc/apt/sources.list > /dev/null
Run Code Online (Sandbox Code Playgroud)

  • 需要注意的一件重要事情:永远不要忘记-a!想象一下`echo'tmpfs/tmp tmpfs默认为0 0'| sudo tee/etc/fstab`会这样做 (38认同)
  • 对于那些不明白@mic_e所说的内容:**没有`-a`**(`--append`)标志**该命令会用给定的字符串覆盖整个文件**而不是附加到结束. (25认同)
  • 在OS X下,这应该是`tee -a`而不是`tee --append`. (20认同)
  • 我同意.似乎比开始新的sh更整洁,特别是可能与环境等做事情. (5认同)
  • 我绝对喜欢这个.它只是最简单的(它让我想起了tee,它在其他场景中也很方便). (3认同)

Mat*_*t P 303

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

请尝试以下代码段:

sudo sh -c "echo 'something' >> /etc/privilegedfile"
Run Code Online (Sandbox Code Playgroud)


Inc*_*ent 32

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

使用这样的东西,也许:

sudo sh -c "echo 'something' >> /etc/privilegedFile"
Run Code Online (Sandbox Code Playgroud)

  • 不适用于echo $ EVN_VARIBLE (3认同)

Vin*_*vic 17

sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"
Run Code Online (Sandbox Code Playgroud)

  • 不适用于echo $ EVN_VARIBLE (3认同)

agn*_*nul 13

sudo sh -c "echo >> somefile"
Run Code Online (Sandbox Code Playgroud)

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

  • 不适用于echo $ EVN_VARIBLE (3认同)

abk*_*rim 10

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

sudo tee -a  /path/file/to/create_with_text > /dev/null <<EOT 
line 1
line 2
line 3
EOT
Run Code Online (Sandbox Code Playgroud)


msa*_*ord 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"
Run Code Online (Sandbox Code Playgroud)

  • 这很好用,除了嵌入的引号可能需要用 \ 转义 (2认同)

Vyt*_*nis 8

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

 echo "# comment" |  sudo tee -a /etc/hosts > /dev/null
Run Code Online (Sandbox Code Playgroud)


hol*_*eap 5

使用Yoo 的答案,将其放入您的~/.bashrc

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

现在你可以运行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
}
Run Code Online (Sandbox Code Playgroud)