JAVA和Nginx 教程大全

网站首页 > 精选教程 正文

Ansible入门---常用模块之包管理模块(yum_repository和yum)

wys521 2024-10-20 11:44:58 精选教程 249 ℃ 0 评论

1. yum_repository模块

yum_repository模块可以帮助我们管理远程主机上的yum仓库。

先看一个yum源配置的例子:

[root@localhost yum.repos.d]# cat dvd.repo 
[RHEL]
name=RHEL6
baseurl=file:///home/isopackage
gpgcheck=0
gpgkey=file:///home/isopackage/RPM-GPG-KEY-redhat-release
enabled=1

(1)参数

name参数:必须参数,用于指定要操作的唯一的仓库ID,也就是".repo"配置文件中每个仓库对应的"中括号"内的仓库ID

baseurl参数:此参数用于设置yum仓库的baseurl

description参数:此参数用于设置仓库的注释信息,也就是".repo"配置文件中每个仓库对应的"name字段"对应的内容。

file参数:此参数用于设置仓库的配置文件名称,即设置".repo"配置文件的文件名前缀,在不使用此参数的情况下,默认以name参数的仓库ID作为".repo"配置文件的文件名前缀,同一个'.repo'配置文件中可以存在多个yum源

enabled参数:此参数用于设置是否激活对应的yum源,此参数默认值为yes,表示启用对应的yum源,设置为no表示不启用对应的yum源。

gpgcheck参数:此参数用于设置是否开启rpm包验证功能,默认值为no,表示不启用包验证,设置为yes表示开启包验证功能。

gpgcakey参数:当gpgcheck参数设置为yes时,需要使用此参数指定验证包所需的公钥

state参数:默认值为present,当值设置为absent时,表示删除对应的yum源

(2)创建

设置ID为aliEpel 的yum源,仓库配置文件路径为/etc/yum.repos.d/aliEpel.repo

[root@centos1 ~]# releasever=7
[root@centos1 ~]# basearch=x86_64
[root@centos1 ~]# ansible webservers -m yum_repository -a "name=aliEpel description=\"alibaba EPEL\" baseurl=https://mirrors.aliyun.com/epel/${releasever}Server/$basearch"
192.168.87.137 | CHANGED => {
 "ansible_facts": {
 "discovered_interpreter_python": "/usr/bin/python"
 }, 
 "changed": true, 
 "repo": "aliEpel", 
 "state": "present"
}
192.168.87.128 | CHANGED => {
 "ansible_facts": {
 "discovered_interpreter_python": "/usr/bin/python"
 }, 
 "changed": true, 
 "repo": "aliEpel", 
 "state": "present"
}

在受管机器上可以看到:

[root@linux1 yum.repos.d]# cat aliEpel.repo 
[aliEpel]
baseurl = https://mirrors.aliyun.com/epel/7Server/x86_64
name = alibaba EPEL

(3)删除

[root@centos1 ~]# ansible webservers -m yum_repository -a 'name=aliEpel state=absent'
192.168.87.137 | CHANGED => {
 "ansible_facts": {
 "discovered_interpreter_python": "/usr/bin/python"
 }, 
 "changed": true, 
 "repo": "aliEpel", 
 "state": "absent"
}
192.168.87.128 | CHANGED => {
 "ansible_facts": {
 "discovered_interpreter_python": "/usr/bin/python"
 }, 
 "changed": true, 
 "repo": "aliEpel", 
 "state": "absent"
}

2. yum模块

yum模块可以帮助我们在远程主机上通过yum源管理软件包。

(1)参数

name参数:必须参数,用于指定需要管理的软件包,比如nginx

state参数:用于指定软件包的状态,默认值为present,表示确保软件包已经安装,除了present,其他可用值有installed、latest、absent、removed,其中installed与presentt等效,latest表示安装yum中最新的版本,absent和removed等效,表示删除对应的软件包。

disable_gpg_check参数:用于禁用对rpm包的公钥gpg验证,默认值为no,表示不禁用验证,设置为yes表示禁用验证,即不验证包,直接安装,在对应的yum源没有开启gpg验证的情况下,需要将此参数的值设置为yes,否则会报错而无法进行安装。

enablerepo参数:用于指定安装软件包时临时启用的yum源,假如你想要从A源中安装软件,但是你不确定A源是否启用了,你可以在安装软件包时将此参数的值设置为yes,这样即使A源的设置是未启用,也可以在安装软件包时临时启用A源。

disablerepo参数:用于指定安装软件包时临时禁用的yum源,某些场景下需要此参数,比如,当多个yum源中同时存在要安装的软件包时,你可以使用此参数临时禁用某个源,这样设置后,在安装软件包时则不会从对应的源中选择安装包。

enablerepo参数和disablerepo参数可以同时使用

(2)例子

[root@centos1 ~]# ansible webservers -m yum -a 'name=gcc disable_gpg_check=yes'
192.168.87.128 | SUCCESS => {
 "ansible_facts": {
 "discovered_interpreter_python": "/usr/bin/python"
 }, 
 "changed": false, 
 "msg": "", 
 "rc": 0, 
 "results": [
 "gcc-4.4.7-4.el6.x86_64 providing gcc is already installed"
 ]
}
192.168.87.128 | SUCCESS => {
 "ansible_facts": {
 "discovered_interpreter_python": "/usr/bin/python"
 }, 
 "changed": false, 
 "msg": "", 
 "rc": 0, 
 "results": [
 "gcc-4.4.7-4.el6.x86_64 providing gcc is already installed"
 ]
}

以下两条命令的效果相同:

ansible webservers -m yum -a 'name=gcc state=present disable_gpg_check=yes'
ansible webservers -m yum -a 'name=gcc state=installed disable_gpg_check=yes'

确保webservers主机上安装了yum源中最新版本的nginx

ansible webservers -m yum -a 'name=nginx state=latest disable_gpg_check=yes'

安装telnet时不确定local源是否启用,使用enablerepo=local确保临时启用local源

ansible webservers -m yum -a 'name=telnet disable_gpg_check=yes enablerepo=local'

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表