shell使用sudo echo x > 时,Permission denied问题

时间:2021-10-23 12:50:16

#!/bin/bash -x
DNS_SERVER=10.xx.xx.xx;
echo "Add DNS Server";
sudo chattr -i /etc/resolv.conf;
sudo echo "nameserver $DNS_SERVER" >> /etc/resolv.conf;
sudo chattr +i /etc/resolv.conf

[oracle@mds ~]$ ./test.sh 
+ DNS_SERVER=10.xx.xx.xx
+ echo 'Add DNS Server'
Add DNS Server
+ sudo chattr -i /etc/resolv.conf
[sudo] password for oracle: 
+ sudo echo 'nameserver 10.xx.xx.xx'
./test.sh: line 6: /etc/resolv.conf: 权限不够
+ sudo chattr +i /etc/resolv.conf
##sudo 配置了Oracle具有root所有权限 但是在执行脚本报错
[root@mds oracle]# ./test.sh        #root用户执行正常     
+ DNS_SERVER=10.xx.xx.xx
+ echo 'Add DNS Server'
Add DNS Server
+ sudo chattr -i /etc/resolv.conf
+ sudo echo 'nameserver 10.xx.xx.xx'
+ sudo chattr +i /etc/resolv.conf
[root@mds oracle]# cat /etc/resolv.conf 
# Generated by NetworkManager
search test.com

# No nameservers found; try putting DNS servers into your
# ifcfg files in /etc/sysconfig/network-scripts like so:
#
DNS1=8.8.8.8
# DNS2=xxx.xxx.xxx.xxx
# DOMAIN=lab.foo.com bar.foo.com
nameserver 10.xx.xx.xx

分析 
在shell脚本中,bash 拒绝这么做,说是权限不够.
这是因为重定向符号 “>” “>>” 也是 bash 的命令。
sudo 只是让 echo 命令具有了 root 权限,但是没有让 “>” 或者 “>>” 
命令也具有root 权限,所以 bash 会认为这个命令没有写入信息的权限。
这时候echo 后面再接>  或者 >> 没有权限执行

解决办法

echo "nameserver $DNS_SERVER" | sudo tee /etc/resolv.conf;

利用管道和 tee 命令,该命令可以从标准输入中读入信息并将其写入标准输出或文件中,
具体用法如下:
echo a |sudo tee 1.txt
echo a |sudo tee -a 1.txt   // -a 是追加的意思,等同于 >>
tee 命令很好用,它从管道接受信息,一边向屏幕输出,一边向文件写入。
或者使用sed -i

 sudo sed -i '$a\string' file.txt

使用 -i 选项直接修改文件。

$ 匹配文件的最后一行位置

a 命令在后面append