这是一个非常简单的问题,至少看起来应该是这样,关于Linux中的sudo权限。
很多时候,我只是想在/etc/hosts或类似的文件中添加一些内容,但最终无法添加,因为>和>>都不允许,即使使用root。
有没有什么方法可以让这个工作,而不需要su或sudo su到root?
这是一个非常简单的问题,至少看起来应该是这样,关于Linux中的sudo权限。
很多时候,我只是想在/etc/hosts或类似的文件中添加一些内容,但最终无法添加,因为>和>>都不允许,即使使用root。
有没有什么方法可以让这个工作,而不需要su或sudo su到root?
当前回答
如何: Echo text | sudo dd status=none of=特权文件 我想更改/proc/sys/net/ipv4/tcp_rmem。 我做了: Sudo dd status=none of=/proc/sys/net/ipv4/tcp_rmem <<<"4096 131072 1024000" 消除单行文档的回显
其他回答
有些用户在使用多条线路时不知道如何解决。
sudo tee -a /path/file/to/create_with_text > /dev/null <<EOT
line 1
line 2
line 3
EOT
在bash中,您可以将tee与> /dev/null结合使用以保持stdout干净。
echo "# comment" | sudo tee -a /etc/hosts > /dev/null
做
sudo sh -c "echo >> somefile"
应该工作。问题是>和>>是由shell处理的,而不是由“sudoed”命令处理的,所以权限是您的,而不是您正在“sudo”进入的用户的权限。
问题是处理重定向的是你的shell;它试图用您的权限打开文件,而不是您在sudo下运行的进程的权限。
可以使用这样的语句:
sudo sh -c "echo 'something' >> /etc/privilegedFile"
你可以改变文件的所有权,然后在使用cat >>追加后将其更改回来吗?
sudo chown youruser /etc/hosts
sudo cat /downloaded/hostsadditions >> /etc/hosts
sudo chown root /etc/hosts
这样的东西对你有用吗?