步骤:
1、建立sudoer文件:
vim /etc/sudoers.d/ovs_sudoers 写入:
#!/etc/sudoers.d/bash
msj ALL = (root) NOPASSWD: /usr/bin/test.sh2、上面的脚本使得目录文件 /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”
本文介绍如何通过Sudo权限配置文件实现指定命令无密码执行,包括配置文件创建、权限设置、错误处理及注意事项。同时,提供了解决特定命令自身需要sudo权限时的配置方法。
6220

被折叠的 条评论
为什么被折叠?



