这是一个非常简单的问题,至少看起来应该是这样,关于Linux中的sudo权限。
很多时候,我只是想在/etc/hosts或类似的文件中添加一些内容,但最终无法添加,因为>和>>都不允许,即使使用root。
有没有什么方法可以让这个工作,而不需要su或sudo su到root?
这是一个非常简单的问题,至少看起来应该是这样,关于Linux中的sudo权限。
很多时候,我只是想在/etc/hosts或类似的文件中添加一些内容,但最终无法添加,因为>和>>都不允许,即使使用root。
有没有什么方法可以让这个工作,而不需要su或sudo su到root?
当前回答
sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"
其他回答
sudo sh -c "echo 127.0.0.1 localhost >> /etc/hosts"
在bash中,您可以将tee与> /dev/null结合使用以保持stdout干净。
echo "# comment" | sudo tee -a /etc/hosts > /dev/null
问题是shell执行输出重定向,而不是sudo或echo,所以这是作为普通用户执行的。
试试下面的代码片段:
sudo sh -c "echo 'something' >> /etc/privilegedfile"
echo 'Hello World' | (sudo tee -a /etc/apt/sources.list)
做
sudo sh -c "echo >> somefile"
应该工作。问题是>和>>是由shell处理的,而不是由“sudoed”命令处理的,所以权限是您的,而不是您正在“sudo”进入的用户的权限。