AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 542910
Accepted
vdboor
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 3 个回答
  • 109092 Views

3 个回答

  • Voted
  1. 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,如果您省略,您的用户将从所有其他组中删除。如果您想使用用户应属于的特定组列表,这将很有用。

    • 131
  2. 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将它们添加到现有用户

    • 64
  3. 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,因为它需要管理权限才能更改组文件
    • 16

相关问题

  • Ansible 剧本,使用选项 --disabled-login 创建用户

  • ansible playbook,操作系统不同的用户

  • ansible:为什么文件模块会跳过?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve