Ansible playbook become 模块一定要配置 sudoers 为 ALL 吗?

2021-03-26 10:45:07 +08:00
 zunxiongchen
ansible playbook

- hosts: backend_host
remote_user: ansible_user
gather_facts: no
become: yes
become_method: sudo
become_user: test_user

目前配置的 sudo nopasswd 是 all
ansible_user ALL=(ALL) NOPASSWD:ALL

感觉 ALL 给的权限太大,想要让 ansible 用户只能单单 sudo 到 test_user,像下边这样。不知道可否实现,有大佬懂吗?
ansible_user ALL=(ALL) NOPASSWD:/bin/su - test_user
1471 次点击
所在节点    Linux
5 条回复
defunct9
2021-03-26 10:49:08 +08:00
直接用 test_user 执行不行么
zunxiongchen
2021-03-26 11:01:01 +08:00
@defunct9 感谢解答,也不是不可以,只是想区分下用户
asilin
2021-03-26 11:08:55 +08:00
生产环境一般都是为 ansible 专门创建一个只能密钥登陆、非交互式 SHELL 、具有完全 sudo 权限的用户
defunct9
2021-03-26 11:58:43 +08:00
哦哦哦

一、在 ansible 配置文件里,ansible.cfg 配
[privilege_escalation]
become_exe=’sudo su -‘

或者干脆环境变量里指出 ANSIBLE_BECOME_EXE=’sudo su -‘

二、再使用 become
remote_user: remote-user
become: yes
become_user: informatica-user
become_method: su
lechain
2021-03-26 12:41:20 +08:00
namespace 走起?或者一步到位,docker 走起

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/765312

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX