[英]sudo echo “something” >> /etc/privilegedFile doesn't work [duplicate]
这是一个非常简单的问题,至少看起来应该是,关于 Linux 中的 sudo 权限。
很多时候,我只想将某些内容附加到/etc/hosts
或类似文件,但最终无法添加,因为>
和>>
都是不允许的,即使使用 root 也是如此。
有没有办法使这项工作无需su
或sudo su
进入根目录?
使用tee --append
或tee -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
) 标志! Just tee
就像>
一样,会覆盖你的文件。 tee -a
作用类似于>>
并将写入文件的末尾。
问题是 shell 执行输出重定向,而不是 sudo 或 echo,所以这是作为您的普通用户完成的。
尝试以下代码片段:
sudo sh -c "echo 'something' >> /etc/privilegedfile"
问题是你的 shell 处理重定向; 它试图用您的权限打开文件,而不是您在 sudo 下运行的进程的权限。
使用这样的东西,也许:
sudo sh -c "echo 'something' >> /etc/privilegedFile"
sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"
正在做
sudo sh -c "echo >> somefile"
应该管用。 问题是 > 和 >> 由您的 shell 处理,而不是由“sudoed”命令处理,因此权限是您的,而不是您“sudo”进入的用户的权限。
我会注意到,出于好奇,您还可以引用一个 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"
在 bash 中,您可以将tee
与> /dev/null
结合使用以保持标准输出干净。
echo "# comment" | sudo tee -a /etc/hosts > /dev/null
使用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
}
通过使用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 选项解释:
您还可以使用moreutils
包中的sponge
,而不需要重定向输出(即,没有要隐藏的tee
噪音):
echo 'Add this line' | sudo sponge -a privfile
一些用户在使用多条线路时不知道解决方案。
sudo tee -a /path/file/to/create_with_text > /dev/null <<EOT
line 1
line 2
line 3
EOT
echo '你好世界' | (sudo tee -a /etc/apt/sources.list)
怎么样:
回声文本 | 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"
用单行文档消除回声
这对我有用:原始命令
echo "export CATALINA_HOME="/opt/tomcat9"" >> /etc/environment
工作指挥
echo "export CATALINA_HOME="/opt/tomcat9"" |sudo tee /etc/environment
您可以更改文件的所有权,然后在使用cat >>
追加后将其更改回来吗?
sudo chown youruser /etc/hosts
sudo cat /downloaded/hostsadditions >> /etc/hosts
sudo chown root /etc/hosts
像这样的东西对你有用吗?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.