Ansible——group模块

目录

参数总结

语法示例

创建用户组

删除用户组

[设置组的 GID](#设置组的 GID)

创建系统组

[修改组的 GID](#修改组的 GID)

添加用户组并附加其他组属性

[删除指定 GID 的用户组](#删除指定 GID 的用户组)

帮助信息

Playbook示例

基本示例

[1. 创建用户组](#1. 创建用户组)

[2. 删除用户组](#2. 删除用户组)

进阶示例

[1. 修改组的 GID](#1. 修改组的 GID)

[2. 综合管理多个用户组](#2. 综合管理多个用户组)

[3. 创建用户组并附加其他组属性](#3. 创建用户组并附加其他组属性)


group 模块用于管理系统中的用户组。它可以创建、修改和删除用户组,以及为组设置特定的属性。在 YAML Playbook 和命令行中都可以使用这个模块来进行组管理。下面是 group 模块的一些常见用法示例:

参数总结

  1. name:

    • 描述:要管理的组的名称。
    • 类型:字符串
    • 必需:是
  2. gid:

    • 描述:设置组的 GID。
    • 类型:整数
  3. state:

    • 描述:组的目标状态。
    • 可选值:
      • present:确保组存在
      • absent:确保组不存在
    • 类型:字符串
    • 默认值:present
  4. system:

    • 描述:如果为 yes,则创建系统组。
    • 类型:布尔值
    • 默认值:no
  5. local:

    • 描述:如果为 yes,则仅在本地管理组,不进行 LDAP 等集中式管理。
    • 类型:布尔值
    • 默认值:no

语法示例

创建用户组

创建一个名为 developers 的组:

ansible all -m group -a "name=developers state=present"
删除用户组

删除名为 developers 的组:

ansible all -m group -a "name=developers state=absent"
设置组的 GID

创建一个名为 staff 且 GID 为 1050 的组:

ansible all -m group -a "name=staff gid=1050 state=present"
创建系统组

创建一个名为 sysadmins 的系统组:

ansible all -m group -a "name=sysadmins system=yes state=present"
修改组的 GID

修改现有组 developers 的 GID 为 2000

ansible all -m group -a "name=developers gid=2000 state=present"
添加用户组并附加其他组属性

创建一个名为 admins 的组,并确保其他属性:

ansible all -m group -a "name=admins gid=1500 system=yes state=present"
删除指定 GID 的用户组

删除 GID 为 1002 的组:

ansible all -m group -a "gid=1002 state=absent"
帮助信息

查看 group 模块的帮助信息:

ansible-doc group

Playbook示例

基本示例
1. 创建用户组

创建一个名为 developers 的组:

---
- name: Create a group named developers
  hosts: all
  tasks:
    - name: Create group developers
      group:
        name: developers
        state: present
2. 删除用户组

删除名为 developers 的组:

---
- name: Remove a group named developers
  hosts: all
  tasks:
    - name: Remove group developers
      group:
        name: developers
        state: absent
  1. 设置组的 GID

创建一个名为 staff 且 GID 为 1050 的组:

---
- name: Create a group named staff with GID 1050
  hosts: all
  tasks:
    - name: Create group staff with GID 1050
      group:
        name: staff
        gid: 1050
        state: present
  1. 创建系统组

创建一个名为 sysadmins 的系统组:

---
- name: Create a system group named sysadmins
  hosts: all
  tasks:
    - name: Create system group sysadmins
      group:
        name: sysadmins
        system: yes
        state: present
进阶示例
1. 修改组的 GID

修改名为 developers 的组的 GID 为 2000

---
- name: Change GID of the group developers
  hosts: all
  tasks:
    - name: Update GID of developers group to 2000
      group:
        name: developers
        gid: 2000
        state: present
2. 综合管理多个用户组

同时创建、修改和删除多个用户组:

---
- name: Comprehensive management of user groups
  hosts: all
  tasks:
    - name: Create group developers
      group:
        name: developers
        state: present

    - name: Create group staff with GID 1050
      group:
        name: staff
        gid: 1050
        state: present

    - name: Create system group sysadmins
      group:
        name: sysadmins
        system: yes
        state: present

    - name: Remove group oldgroup
      group:
        name: oldgroup
        state: absent
3. 创建用户组并附加其他组属性

创建一个名为 admins 的组,并确保其他属性:

---
- name: Create and configure admins group
  hosts: all
  tasks:
    - name: Ensure group admins exists with GID 1500 as a system group
      group:
        name: admins
        gid: 1500
        system: yes
        state: present

综合示例如下:

---
- name: Comprehensive management of user groups
  hosts: all
  tasks:
    - name: Create group developers
      group:
        name: developers
        state: present

    - name: Create group staff with GID 1050
      group:
        name: staff
        gid: 1050
        state: present

    - name: Create system group sysadmins
      group:
        name: sysadmins
        system: yes
        state: present

    - name: Remove group oldgroup
      group:
        name: oldgroup
        state: absent

    - name: Change GID of group developers to 2000
      group:
        name: developers
        gid: 2000
        state: present
相关推荐
飞行的俊哥3 小时前
Linux 内核学习 3b - 和copilot 讨论pci设备的物理地址在内核空间和用户空间映射到虚拟地址的区别
linux·驱动开发·copilot
hunter2062065 小时前
ubuntu向一个pc主机通过web发送数据,pc端通过工具直接查看收到的数据
linux·前端·ubuntu
不会飞的小龙人6 小时前
Docker Compose创建镜像服务
linux·运维·docker·容器·镜像
不会飞的小龙人6 小时前
Docker基础安装与使用
linux·运维·docker·容器
白粥行7 小时前
linux-ubuntu学习笔记碎记
linux·ubuntu
jerry-897 小时前
通过配置核查,CentOS操作系统当前无多余的、过期的账户;但CentOS操作系统存在共享账户r***t
linux
涛ing8 小时前
21. C语言 `typedef`:类型重命名
linux·c语言·开发语言·c++·vscode·算法·visual studio
0xfather8 小时前
在Debian系统中安装Debian(Linux版PE装机)
linux·服务器·debian
workingman_li8 小时前
centos虚拟机异常关闭,导致数据出现问题
linux·运维·centos
Fireworkitte9 小时前
linux环境变量配置文件区别 /etc/profile和~/.bash_profile
linux