linux shell 避免’sudo echo x >’ 时’Permission denied’

[wj@rsync-client ~]$ sudo echo "nameserver 114.114.114.144" >> /etc/resolv.conf
-bash: /etc/resolv.conf: Permission denied

分析:这是因为重定向符号 “>” 也是 bash 的命令。sudo 只是让 echo 命令具有了 root 权限,
但是没有让 “>” 命令也具有root 权限,所以 bash 会认为这个命令没有写入信息的权限。

 解决办法。三种:
1. 利用 “sh -c” 命令,它可以让 bash 将一个字串作为完整的命令来执行,这样就可以将 sudo 的影响范围扩展到整条命令。
具体用法如下:

[wj@rsync-client ~]$ sudo sh -c 'echo "nameserver 114.114.114.144" >> /etc/resolv.conf'

利用bash -c 也是一样的,现在bash shell 流行。

2.  利用管道和 tee 命令,该命令可以从标准输入中读入信息并将其写入标准输出或文件中,
具体用法如下:
echo "nameserver 114.114.114.144"|sudo tee -a /etc/resolv.conf  // -a 是追加的意思,等同于 >>

tee 命令很好用,它从管道接收信息,一边向屏幕输出,一边向文件写入。

配置文件resolv.conf每一行对应一个dns域名解析器,这个修改后直接生效,不需要重启网卡/etc/init.d/network restart

3. 提升shell 权限。
sudo -s  或sudo su - root     //提到root 权限。提示符为#
当你觉得该退回到普通权限时,
sudo su - username //退回到username 权限,提示符为$

exit 退出当前用户,回到上一层目录.

centos 提升权限: su  -

ubuntu 提升权限: sudu -s, sudo su

猜你喜欢

转载自blog.csdn.net/qq_34412985/article/details/84330320