vdboor Asked: 2013-10-02 02:20:22 +0800 CST2013-10-02 02:20:22 +0800 CST 2013-10-02 02:20:22 +0800 CST 使用 ansible 将用户添加到其他组 772 如何使用 Ansible 将用户添加到其他组?例如,我想在sudo不替换用户现有组集的情况下将用户添加到组中。 ansible 3 个回答 Voted admirabilis 2016-08-28T06:13:06+08:002016-08-28T06:13:06+08:00 如果{{ user }}系统中已经存在,您应该使用以下命令将其添加到组中: - name: adding existing user '{{ user }}' to group sudo user: name: '{{ user }}' groups: sudo append: yes 要将其添加到一组组中,您可以使用逗号分隔的列表,例如groups: admin,sudo. 请注意,根据usermod 手册页append: yes,如果您省略,您的用户将从所有其他组中删除。如果您想使用用户应属于的特定组列表,这将很有用。 Best Answer art3mis 2013-10-25T08:04:45+08:002013-10-25T08:04:45+08:00 根据用户模块,您可以使用它: - name: Adding user {{ user }} user: name={{ user }} group={{ user }} shell=/bin/bash password=${password} groups=sudo append=yes 您可以在创建它们时添加groups=groupname和append=yes将它们添加到现有用户 ctW7dY2RcIY0pN010bC7Rv7N0 2020-01-16T20:26:26+08:002020-01-16T20:26:26+08:00 请注意,这{{ user }}已更改为{{ ansible_user }}最近的 Ansible 版本(https://github.com/ansible/ansible/blob/c600ab81ee/lib/ansible/playbook/play_context.py#L46-L55)。或者,您也可以使用ansible_ssh_user- 它是相同的。因此,来自 admirabilis 的更新代码如下所示: - name: adding existing user "{{ ansible_user }}" to group sudo user: name: "{{ ansible_user }}" groups: sudo append: yes become: yes 更多修复: 使用双引号使变量扩展 添加become: yes,因为它需要管理权限才能更改组文件
如果
{{ user }}
系统中已经存在,您应该使用以下命令将其添加到组中:要将其添加到一组组中,您可以使用逗号分隔的列表,例如
groups: admin,sudo
.请注意,根据usermod 手册页
append: yes
,如果您省略,您的用户将从所有其他组中删除。如果您想使用用户应属于的特定组列表,这将很有用。根据用户模块,您可以使用它:
您可以在创建它们时添加
groups=groupname
和append=yes
将它们添加到现有用户请注意,这
{{ user }}
已更改为{{ ansible_user }}
最近的 Ansible 版本(https://github.com/ansible/ansible/blob/c600ab81ee/lib/ansible/playbook/play_context.py#L46-L55)。或者,您也可以使用ansible_ssh_user
- 它是相同的。因此,来自 admirabilis 的更新代码如下所示:更多修复:
become: yes
,因为它需要管理权限才能更改组文件