这是一个非常简单的问题,至少看起来应该是这样,关于Linux中的sudo权限。
很多时候,我只是想在/etc/hosts或类似的文件中添加一些内容,但最终无法添加,因为>和>>都不允许,即使使用root。
有没有什么方法可以让这个工作,而不需要su或sudo su到root?
这是一个非常简单的问题,至少看起来应该是这样,关于Linux中的sudo权限。
很多时候,我只是想在/etc/hosts或类似的文件中添加一些内容,但最终无法添加,因为>和>>都不允许,即使使用root。
有没有什么方法可以让这个工作,而不需要su或sudo su到root?
当前回答
在bash中,您可以将tee与> /dev/null结合使用以保持stdout干净。
echo "# comment" | sudo tee -a /etc/hosts > /dev/null
其他回答
通过使用sed -i和$ a,可以在最后一行之后附加文本,其中包含变量和特殊字符。
例如,将$NEW_HOST和$NEW_IP添加到/etc/hosts:
sudo sed -i "\$ a $NEW_IP\t\t$NEW_HOST.domain.local\t$NEW_HOST" /etc/hosts
Sed选项说明:
-i for in-place $ for最后一行 A表示追加
你也可以使用海绵从moreutils包,不需要重定向输出(即,没有tee噪声隐藏):
echo 'Add this line' | sudo sponge -a privfile
在bash中,您可以将tee与> /dev/null结合使用以保持stdout干净。
echo "# comment" | sudo tee -a /etc/hosts > /dev/null
问题是处理重定向的是你的shell;它试图用您的权限打开文件,而不是您在sudo下运行的进程的权限。
可以使用这样的语句:
sudo sh -c "echo 'something' >> /etc/privilegedFile"
echo 'Hello World' | (sudo tee -a /etc/apt/sources.list)