记录在shell脚本中使用sudo echo x > 时,抛Permission denied
发布时间:2020-12-15 21:12:26 所属栏目:安全 来源:网络整理
导读:1.场景 在一个非root且带有sudo权限的用户,使用shell脚本(单独手工执行命令不会抛错,是成功的):会抛错 #!/bin/bash -xDNS_SERVER=10.xx.xx.xx;echo "Add DNS Server";sudo chattr -i /etc/resolv.conf;sudo echo "nameserver $DNS_SERVER" /etc/resolv.co
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.错误 [[email?protected] 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 命令很好用,它从管道接受信息,一边向屏幕输出,一边向文件写入。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |