今天就跟大家聊聊有关shell脚本中使用sudo echo x > 时,抛Permission denied的错误是什么样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
1.场景
在一个非root且带有sudo权限的用户,使用shell脚本(单独手工执行命令不会抛错,是成功的):会抛错
#!/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
2.错误
[hadoop@emr-header-1 WNE-2280FFD89A744E81]$ ./init-emr-env.sh
+ DNS_SERVER=10.xx.xx.xx
+ echo 'Add DNS Server'
Add DNS Server
+ sudo chattr -i /etc/resolv.conf
+ sudo echo 'nameserver 10.xxx.xx.xx'
./init-emr-env.sh: line 7: /etc/resolv.conf: Permission denied
+ sudo chattr +i /etc/resolv.conf
+ echo 'remove hive2.0'
3.分析
在shell脚本中,bash 拒绝这么做,说是权限不够.
这是因为重定向符号 “>” 也是 bash 的命令。sudo 只是让 echo 命令具有了 root 权限,但是没有让 “>” 命令也具有root 权限,所以 bash 会认为这个命令没有写入信息的权限。
4.解决方法
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 命令很好用,它从管道接受信息,一边向屏幕输出,一边向文件写入。
看完上述内容,你们对shell脚本中使用sudo echo x > 时,抛Permission denied的错误是什么样的有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。