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
相关推荐
云计算练习生37 分钟前
linux shell编程实战 10 Git工具详解与运维场景实战
linux·运维·git
虚伪的空想家3 小时前
KVM的ubuntu虚机如何关闭安全启动
linux·安全·ubuntu
t198751288 小时前
在Ubuntu 22.04系统上安装libimobiledevice
linux·运维·ubuntu
skywalk81638 小时前
linux安装Code Server 以便Comate IDE和CodeBuddy等都可以远程连上来
linux·运维·服务器·vscode·comate
晚风吹人醒.9 小时前
缓存中间件Redis安装及功能演示、企业案例
linux·数据库·redis·ubuntu·缓存·中间件
Hard but lovely10 小时前
linux: pthread库的使用和理解
linux
这儿有一堆花12 小时前
Kali Linux:探测存活到挖掘漏洞
linux·运维·服务器
松涛和鸣12 小时前
从零开始理解 C 语言函数指针与回调机制
linux·c语言·开发语言·嵌入式硬件·排序算法
皮小白13 小时前
ubuntu开机检查磁盘失败进入应急模式如何修复
linux·运维·ubuntu
邂逅星河浪漫13 小时前
【CentOS】虚拟机网卡IP地址修改步骤
linux·运维·centos