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

很多时候,我只是想在/etc/hosts或类似的文件中添加一些内容,但最终无法添加,因为>和>>都不允许,即使使用root。

有没有什么方法可以让这个工作,而不需要su或sudo su到root?


当前回答

这招对我很管用: 原始的命令

echo "export CATALINA_HOME="/opt/tomcat9"" >> /etc/environment

工作命令

echo "export CATALINA_HOME="/opt/tomcat9"" |sudo tee /etc/environment

其他回答

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

可以使用这样的语句:

sudo sh -c "echo 'something' >> /etc/privilegedFile"

sudo sh -c "echo >> somefile"

应该工作。问题是>和>>是由shell处理的,而不是由“sudoed”命令处理的,所以权限是您的,而不是您正在“sudo”进入的用户的权限。

echo 'Hello World' | (sudo tee -a /etc/apt/sources.list)

你可以改变文件的所有权,然后在使用cat >>追加后将其更改回来吗?

sudo chown youruser /etc/hosts  
sudo cat /downloaded/hostsadditions >> /etc/hosts  
sudo chown root /etc/hosts  

这样的东西对你有用吗?

问题是shell执行输出重定向,而不是sudo或echo,所以这是作为普通用户执行的。

试试下面的代码片段:

sudo sh -c "echo 'something' >> /etc/privilegedfile"