这是一个非常简单的问题,至少看起来应该是这样,关于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 sh -c "echo 127.0.0.1 localhost >> /etc/hosts"

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

试试下面的代码片段:

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

通过使用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表示追加

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

可以使用这样的语句:

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

如何: 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" 消除单行文档的回显