Ansible——yum模块

目录

参数总结

[1. 安装软件包](#1. 安装软件包)

安装单个软件包

安装多个软件包

从特定仓库安装

[安装包并禁用 GPG 检查](#安装包并禁用 GPG 检查)

简单的命令行帮助

[2. 更新软件包](#2. 更新软件包)

更新单个软件包到最新版本

更新所有可升级的软件包

[3. 删除软件包](#3. 删除软件包)

删除单个软件包

删除多个软件包

[4. 安装特定版本的软件包](#4. 安装特定版本的软件包)

[5. 禁用并清理无用的包](#5. 禁用并清理无用的包)

Playbook示例

示例1:安装软件包

示例2:安装多个软件包

示例3:更新软件包

示例4:删除软件包

示例5:从特定仓库安装软件包

示例6:安装特定版本的软件包

[示例7:禁用 GPG 检查](#示例7:禁用 GPG 检查)

示例8:安装组包

示例9:安装所有可升级的软件包

示例10:卸载并清理无用的软件包


yum 模块是 Ansible 用于管理 Red Hat 及其衍生发行版(如 CentOS 和 Fedora)上的软件包的模块。使用 yum 模块可以方便地安装、更新、删除和管理软件包。

参数总结

  1. name:

    • 描述:要管理的软件包名称。可以指定一个包名称、包名称和版本,或一个 URL 指向的包。
    • 类型:字符串或列表
    • 必需:否(如果使用了 liststate 参数)
  2. state:

    • 描述:包的目标状态。
    • 可选值:present(确保包已安装)、absent(确保包已移除)、latest(确保安装最新版本)、reinstalled(重新安装包)
    • 类型:字符串
    • 默认值:present
  3. enablerepo:

    • 描述:启用指定的 YUM 库。
    • 类型:字符串或列表
  4. disablerepo:

    • 描述:禁用指定的 YUM 库。
    • 类型:字符串或列表
  5. exclude:

    • 描述:排除安装或更新指定的包。
    • 类型:字符串或列表
  6. allow_downgrade:

    • 描述:允许降级包到较低版本。
    • 类型:布尔值
    • 默认值:no
  7. update_cache:

    • 描述:在执行操作前更新 YUM 缓存。
    • 类型:布尔值
    • 默认值:no
  8. validate_certs:

    • 描述:使用 SSL 时验证服务端证书。
    • 类型:布尔值
    • 默认值:yes
  9. conf_file:

    • 描述:指定自定义的 YUM 配置文件。
    • 类型:字符串
  10. disable_gpg_check:

    • 描述:禁用 GPG 签名检查。
    • 类型:布尔值
    • 默认值:no
  11. autoremove:

    • 描述:如果为 yes,则自动删除所有未使用的依赖项。
    • 类型:布尔值
    • 默认值:no

1. 安装软件包

安装单个软件包
ansible all -m yum -a "name=nginx state=present"
安装多个软件包
ansible all -m yum -a "name=nginx,git,vim state=present"
从特定仓库安装
ansible all -m yum -a "name=nginx enablerepo=epel state=present"
安装包并禁用 GPG 检查
ansible all -m yum -a "name=nginx disable_gpg_check=yes state=present"
简单的命令行帮助

要获取 yum 模块的所有选项和参数,可以使用以下命令查看详细帮助:

ansible-doc -s yum

2. 更新软件包

更新单个软件包到最新版本
ansible all -m yum -a "name=nginx state=latest"
更新所有可升级的软件包
ansible all -m yum -a "name=* state=latest"

3. 删除软件包

删除单个软件包
ansible all -m yum -a "name=nginx state=absent"
删除多个软件包
ansible all -m yum -a "name=nginx,git state=absent"

4. 安装特定版本的软件包

ansible all -m yum -a "name=nginx-1.14.1 state=present"

5. 禁用并清理无用的包

安装 yum-utils 并使用 package-cleanup 命令:

ansible all -m yum -a "name=yum-utils state=present"
ansible all -a "package-cleanup --oldkernels --count=2"
ansible all -a "package-cleanup --leaves"

Playbook示例

示例1:安装软件包

创建一个 Playbook 文件 install_packages.yml ,用于安装 nginx 软件包:

---
- name: Install Nginx
  hosts: all
  tasks:
    - name: Ensure nginx is installed
      yum:
        name: nginx
        state: present
示例2:安装多个软件包

可以在同一个任务中安装多个软件包,例如 nginxgitvim

---
- name: Install Multiple Packages
  hosts: all
  tasks:
    - name: Ensure nginx, git, and vim are installed
      yum:
        name: 
          - nginx
          - git
          - vim
        state: present
示例3:更新软件包

nginx 软件包更新到最新版本:

---
- name: Update Nginx
  hosts: all
  tasks:
    - name: Ensure nginx is the latest version
      yum:
        name: nginx
        state: latest
示例4:删除软件包

删除 nginx 软件包:

---
- name: Remove Nginx
  hosts: all
  tasks:
    - name: Ensure nginx is absent
      yum:
        name: nginx
        state: absent
示例5:从特定仓库安装软件包

epel 仓库安装 nginx 软件包:

---
- name: Install Nginx from EPEL Repo
  hosts: all
  tasks:
    - name: Ensure nginx is installed from EPEL repository
      yum:
        name: nginx
        enablerepo: epel
        state: present
示例6:安装特定版本的软件包

安装 nginx 的特定版本 1.14.1

---
- name: Install Specific Version of Nginx
  hosts: all
  tasks:
    - name: Ensure nginx 1.14.1 is installed
      yum:
        name: nginx-1.14.1
        state: present
示例7:禁用 GPG 检查

安装 nginx 软件包并禁用 GPG 检查:

---
- name: Install Nginx with GPG Check Disabled
  hosts: all
  tasks:
    - name: Ensure nginx is installed with GPG check disabled
      yum:
        name: nginx
        disable_gpg_check: yes
        state: present
示例8:安装组包

安装 Development Tools 组包:

---
- name: Install Development Tools Group
  hosts: all
  tasks:
    - name: Ensure Development Tools are installed
      yum:
        name: "@Development Tools"
        state: present
示例9:安装所有可升级的软件包

更新所有可升级的软件包:

---
- name: Update All Packages to Latest Version
  hosts: all
  tasks:
    - name: Update all packages to the latest version
      yum:
        name: '*'
        state: latest
示例10:卸载并清理无用的软件包

安装 yum-utils 并使用 package-cleanup 命令清理无用的软件包:

---
- name: Cleanup Unnecessary Packages
  hosts: all
  tasks:
    - name: Install yum-utils
      yum:
        name: yum-utils
        state: present

    - name: Remove unnecessary packages
      shell: package-cleanup --leaves --exclude-bin
      become: yes
相关推荐
QMCY_jason7 分钟前
Ubuntu 安装RUST
linux·ubuntu·rust
慕雪华年11 分钟前
【WSL】wsl中ubuntu无法通过useradd添加用户
linux·ubuntu·elasticsearch
苦逼IT运维27 分钟前
YUM 源与 APT 源的详解及使用指南
linux·运维·ubuntu·centos·devops
仍有未知等待探索44 分钟前
Linux 传输层UDP
linux·运维·udp
zeruns8021 小时前
如何搭建自己的域名邮箱服务器?Poste.io邮箱服务器搭建教程,Linux+Docker搭建邮件服务器的教程
linux·运维·服务器·docker·网站
卑微求AC1 小时前
(C语言贪吃蛇)16.贪吃蛇食物位置随机(完结撒花)
linux·c语言·开发语言·嵌入式·c语言贪吃蛇
Hugo_McQueen1 小时前
pWnos1.0 靶机渗透 (Perl CGI 的反弹 shell 利用)
linux·服务器·网络安全
XY.散人2 小时前
初识Linux · 文件(1)
linux·运维·服务器
叶北辰CHINA3 小时前
nginx反向代理,负载均衡,HTTP配置简述(说人话)
linux·运维·nginx·http·云原生·https·负载均衡
不惑_3 小时前
在 Ubuntu 安装 Python3.7(没有弯路)
linux·运维·ubuntu