Answers:
使用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
)标志!就像tee
这样>
,将覆盖您的文件。tee -a
的工作方式类似>>
,并将写入文件末尾。
echo 'tmpfs /tmp tmpfs defaults 0 0' | sudo tee /etc/fstab
会做什么
tee -a
而不是tee --append
。
-a
(--append
)标志,该命令将使用给定的字符串覆盖整个文件,而不是将其附加到末尾。
问题在于外壳程序确实输出重定向,而不是sudo或echo,因此这是以常规用户的身份完成的。
尝试以下代码片段:
sudo sh -c "echo 'something' >> /etc/privilegedfile"
sh
,echo可以像\t
单引号内一样解释转义序列。您可以printf %s 'something'
改用。
sudo /bin/bash -c "echo 'fs.inotify.max_user_watches = 524288' > /etc/sysctl.d/60-golang-inotify.conf"
例如。
问题是处理重定向的是您的外壳;它正在尝试使用您的权限而不是您在sudo下运行的进程的权限打开文件。
使用这样的东西,也许:
sudo sh -c "echo 'something' >> /etc/privilegedFile"
sudo
(出于安全原因)不会将环境传播到子进程。您可以sudo -E
用来绕过此限制。
sudo sh -c "echo 'something' >> $FILENAME"
使用双引号执行此操作,则将起作用-变量替换由外壳程序完成,而不是由sudoed外壳程序完成。
sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"
我会好奇地指出,您也可以引用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和$ NEW_IP添加到/ etc / hosts:
sudo sed -i "\$ a $NEW_IP\t\t$NEW_HOST.domain.local\t$NEW_HOST" /etc/hosts
sed选项说明:
如何:
回声文字| 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
tee -a
。只是tee
会覆盖文件!
您可以更改文件的所有权,然后在使用cat >>
追加后将其更改回吗?
sudo chown youruser /etc/hosts
sudo cat /downloaded/hostsadditions >> /etc/hosts
sudo chown root /etc/hosts
像这样的东西适合您吗?