步骤:
1、建立sudoer文件:
vim /etc/sudoers.d/ovs_sudoers
写入:
#!/etc/sudoers.d/bash
msj ALL = (root) NOPASSWD: /usr/bin/test.sh
2、上面的脚本使得目录文件 /usr/bin/test.sh文件不再需要使用密码访问及执行
3、此时可能会有如下报错:
sudo: /etc/sudoers.d/ovs_sudoers is mode 0644, should be 0440
4、更改权限:
sudo chmod 440 /etc/sudoers.d/ovs_sudoers
5、OK,此时在其他地方通过sudo调用test.sh时不再需要输入密码啦!
注意:
以上的这种做法实际上是有问题的,那就是只要文件的名称是test.sh,那么都不再需要输入密码了!
Pay attention please!
但是:当test.sh里面的命令本身需要sudo权限时,这样做的话并不能解决问题。解决方案如下:
步骤:
1、首先你需要确定里面的命令的启动路径,使用如下命令:
whereis ovs-vsctl
得到:ovs-vsctl: /usr/local/bin/ovs-vsctl
//这就是这条shell命令的路径。(我居然一直以为要整条命令都敲上去。。蠢哭了。。)
2、然后更改上面的ovs_sudoers文件:
#!/etc/sudoers.d/bash
msj ALL = (root) NOPASSWD: /usr/local/bin/ovs-vsctl
3、这样你执行ovs相关的命令都不再需要输入密码啦!但是注意请输入命令的时候加上
“sudo”