看完这243张图片,轻松掌握 Ansible !
Posted 民工哥技术之路
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了看完这243张图片,轻松掌握 Ansible !相关的知识,希望对你有一定的参考价值。
每天10点为你分享不一样的干货
Ansible是什么?
ansible架构图
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ef82afedc3ac44ac9d7ae97b52f8acac.jpg)
ansible特性
模块化:调用特定的模块,完成特定的任务;
基于Python语言研发,由Paramiko, PyYAML和Jinja2三个核心库实现;
部署简单:agentless;
支持自定义模块,使用任意编程语言;
强大的playbook机制;
幂等性;
安装及程序环境
程序:
ansible
ansible-playbook
ansible-doc
配置文件:
/etc/ansible/ansible.cfg
主机清单:
/etc/ansible/hosts
插件目录:
/usr/share/ansible_plugins/
安装ansible
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/046edf110efd469785dc266a23047456.jpg)
安装依赖包
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ea5c9a7b87d2475197ac35681ea98d34.jpg)
ansible命令的使用
Usage: ansible <host-pattern> [options]
常用选项:
-m MOD_NAME
-a MOD_ARGS
配置Host Inventory
/etc/ansible/hosts
[group_id]
HOST_PATTERN1
HOST_PATTERN2
示例:
首先对此文件进行备份操作,以防后面需要用到默认配置文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/1afd016050bf4245b8b8b2026e673d4c.jpg)
进入到/etc/ansible/hosts文件,此处绿色光标以下的内容是没有用的,都是示例,可以删除掉,然后添加我们下面实验操作用到的主机。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/a3298404c10d4be8bd597d57731a4b85.jpg)
添加一组websrvs服务器,以用于下面的测试
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/734736dc41ef4a75b7491f4696723271.jpg)
测试主机连通性
这里报错是因为实验用的主机交换其他两台主机的公钥/私钥的原因导致的
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/636182c4cbb9422784bd9953cf46154c.jpg)
实验SSH免密码登陆设置
生成私钥和公钥 ssh-keygen -t rsa -P ''
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/0eb445a6eb6e4c86a85c8cd110d28dd3.jpg)
复制公钥文件问authorized_keys
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/3c90907c1d2f43dba1f3404514608f64.jpg)
把公钥传送到其他主机
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e30ad86d5f8c4e04abf8ecbe288c6875.jpg)
在68的主机上面可以看见公钥已经传送过来了,并且确认文件的权限是否正确
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/97c2e4f3bb7348eb853a52974bdff903.jpg)
重复以上操作把公钥发送给69的主机
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/02e3b9446c96418eb4d96eb5719c5004.jpg)
然后重新执行ansible的ping模块命令查看该两台主机的连通性
可以发现此时已经成功,那么下面就开始介绍ansilbe的其他模块
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/9af5cbc9b9fc4e138516ab9749af1dc2.jpg)
最后记得利用ansible同步一下所有主机的时间,以免某主机的时间有错误,后面看日志起来会造成混乱
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/5a68e85086af40edac8895daa0a45e50.jpg)
ansible模块
获取模块列表:ansible-doc -l
获取指定模块的使用帮助:ansible-doc -s MOD_NAME
常用模块:
ping模块:探测目标主机是否存活;
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ad69977f7b914b4cb7823f42b12c4f2b.jpg)
示例:测试所有的主机的连通性
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/d27156c71dfe411caf17c918e8cd0c8b.jpg)
command模块:在远程主机执行命令;
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e6bcd2937f2a406cb301879d56d6167b.jpg)
示例1:让所有主机同步时间
此处没有给出指定的-m command命令,是因为ansible的模块默认就是command
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/5a68e85086af40edac8895daa0a45e50.jpg)
示例2:让每一台主机都执行uname -r命令
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/f0df12ee78cc4b238114e798c61fdb80.jpg)
示例3:在主机上面都创建一个用户
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/6f153e6f8896402890124a916321cdf5.jpg)
查看两台主机是否已经创建该用户
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/bc41462766044c7ea31b88391cc2b37a.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/30bdfc93770d462486bd065a352154b0.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/3699838bf89243cabb00debc13414c3c.jpg)
查看用户信息:
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/842868816ca04086a6f1ae4345892acc.jpg)
帮这两个用户改密码,此处需要注意的是,虽然用下面的命令看似执行成功,但是当我们验证的时候,就会发现密码错误了,这是因为ansible的command模块并不支持管道等输出,所以下面介绍另外一个ansible的模块shell
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/fd30d27129e94ff9a137f9c43685109a.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c105e54be0a34e7e9623a5b7a2a6e0de.jpg)
shell模块:在远程主机上调用shell解释器运行命令,支持shell的各种功能,例如管道等
注意:command和shell模块的核心参数直接为命令本身;而其它模块的参数通常为“key=value”格式;
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/6e5cd27bfcd94a8dbc5b3cb969c55f70.jpg)
示例:批量修改其他主机的特定用户的密码
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/f3a4728d35b44954ae34a301aa5aad61.jpg)
此时可以发现已经可以登陆成功
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/f2f89aad19934569bddc4f373c592c56.jpg)
copy模块:复制文件到远程主机
用法:
(1) 复制文件
-a "src= dest= "
(2) 给定内容生成文件
-a "content= dest= "
其它参数:mode, owner, group, ...
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/b1740f4ce090496f91fed3509bafbdc6.jpg)
示例:复制文件到其他主机
此处创建一个测试文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/b2fc08a1824a4093b0a740762c81a2f1.jpg)
复制文件到其他主机
下面红色的报错信息是,如果要传送文件,该主机的指定目录需要存在,如果不存在,就是提示错误
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/28457d6ef59146339057adff972cd306.jpg)
创建对应的目录
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/957b651b5f364a1a844d87d696f7f17c.jpg)
重新传送文件,已经没有错误提示,但是此处也可以看见,如果文件已经存在,则原文件会被覆盖掉,并且此处也没有任何提示覆盖文件的信息,所以操作的时候就需要注意了,以免覆盖掉重要的文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/553937ef408d470aa54788d8dbdde0b5.jpg)
验证文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/851c651a462647a5a34227d4c256d0f2.jpg)
file模块:设置文件的属性
用法:
(1) 创建目录:
-a "path= state=directory"
(2) 创建链接文件:
-a "path= src= state=link"
(3) 删除文件:
-a "path= state=absent“
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/dfaf1347b2f648238ea8c32d4297bacd.jpg)
示例:修改文件的权限和属主
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/cc7beff9cf224aafae82aaab2c014af7.jpg)
验证文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/d09d126a061245268b52b09a974feaee.jpg)
示例:创建文件的软连接
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/f1e756de62604f7ab3dfac496ef2ac0e.jpg)
验证文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/70d34be30953420d9ed65ad8c06a2b38.jpg)
设置文件的状态为absent(即删除文件)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/d74180adff2e4bda99cce922a908a4f5.jpg)
验证
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/7f4b056160c94297aac34a075ebdda0a.jpg)
fetch模块:从远程主机拿文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ed9323321de74d9eba4938a377ecccb7.jpg)
示例:从10.1.156.69主机拿一个文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/5297e9d4015f41809dc14a82f368d136.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/528c7ee478744eac9acac89c53a4a514.jpg)
cron模块:管理计划任务条目
用法:
-a ""
minute=
hour=
day=
month=
weekday=
job=
name=
user=
state={present|absent}
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/9c0420c376654d7089a746d136aeed48.jpg)
示例:创建一个同步时间的计划任务,每5分钟同步一下服务器的时间
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e84a6fcbef124bfbb279a4ec74686cb1.jpg)
验证任务
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c917f6236a8540c4b1070aa9c1d9e257.jpg)
示例:删除计划任务
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/1646ea1bc2674aeea2c707b192fca632.jpg)
验证
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/715a14e0aa42450bb295e4a54c384d64.jpg)
hostname模块:管理主机名
用法:
name=
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/8ca0d1df2fe94b7b9b9a7847f709cce2.jpg)
示例:修改主机名
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e76fc9c82b0148e89c4281580cda3d21.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/74adb5482a3a4849892b1327890bcdec.jpg)
yum模块:使用yum命令完成程序包管理
用法:
-a ""
(1) name= state={present|latest}
(2) name= state=absent
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/13b1f02330c1404d9da05625a27cef1d.jpg)
示例:安装指定包
此实验,首先,确定主机的yum源是可用的,否则实验会失败
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e0ec9a60c7c24c4e9d9e5dd12be9a5e7.jpg)
安装samba包
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/6c16f6648c364eaca99fdbf83fd9b427.jpg)
验证
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/6810c682e82e4d5dab8171adbdcba9aa.jpg)
删除samba安装包
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/738af68bc08744e9917c64bab132a9eb.jpg)
已经没有安装的字眼了
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/569cafa09db94b489c2b20b5eeb53f2f.jpg)
service模块:服务管理
用法:
-a ""
name=
state=
started
stopped
restarted
enabled=
runlevel=
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/da4ea9f19bbf49eead21dcf69191b62e.jpg)
示例:开启主机的httpd服务
首先我们确认httpd服务是关闭的
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/8169354fc050408eb95b6d6e623facb2.jpg)
开启httpd服务,并且设置为开机启动
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/70218fb343e444a4949dc4a07ed5a6dc.jpg)
验证,80端口已经开启
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/bb89951c01e8421b945cdf9ef71347e2.jpg)
group模块:增加或删除组
用法:
-a ""
name=
state=
system=
gid=
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/1b4e55828cc2437ea7a353da089c3403.jpg)
示例:添加一个组
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/de6d2dd920694efc828db326935fd16e.jpg)
验证
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/b877bd0ef61843df84f77fce8eac79c1.jpg)
删除组
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/73f4cd20d5894b0cbff5f018cdf44ac9.jpg)
验证
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/4801b89d77e449d5a1cf57cc82d41081.jpg)
user模块:用户管理
使用格式:
name= : 创建的用户名
state= : present新增,absent删除
force= : 删除用户的时候删除家目录
system= : 创建系统用户
uid= : 指定UID
shell= : 指定shell
home= : 指定用户家目录
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/25fa662b9bf44d4ebb6945c1c921afec.jpg)
示例:增加一个系统用户
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/675b039d3b594432862f572e3efcca1d.jpg)
验证
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/df533026f8b14fa9a7d267621f57e135.jpg)
删除用户
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/f2b344569fb14a198ba166f3d3a31d2a.jpg)
setup模块:收集主机里面的各种信息
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/1894a6ed1a924cd6820c1510bd418b43.jpg)
示例:收集所有主机的信息
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/4b5f21c28f0d4c139aa61d132f15b32d.jpg)
YAML:一种数据序列化工具的语言格式
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/0a3cb1fb935248bdbe5abc5886109f3b.jpg)
数据结构:
key:value
- item1
- item2
- item3
例如{name:jerry, age:21}
PlayBook
核心元素:
Tasks:任务,由模块定义的操作的列表;
Variables:变量
Templates:模板,即使用了模板语法的文本文件;
Handlers:由特定条件触发的Tasks;
Roles:角色;
playbook的基础组件:
Hosts:运行指定任务的目标主机;
remote_user:在远程主机以哪个用户身份执行;
sudo_user:非管理员需要拥有sudo权限;
tasks:任务列表
模块,模块参数:
格式:
(1) action: module arguments
(2) module: arguments
运行playbook,使用ansible-playbook命令
(1) 检测语法
ansible-playbook --syntax-check /path/to/playbook.yaml
(2) 测试运行
ansible-playbook -C /path/to/playbook.yaml
--list-hosts
-list-tasks
--list-tags
(3) 运行
ansible-playbook /path/to/playbook.yaml
-t TAGS, --tags=TAGS
--skip-tags=SKIP_TAGS
--start-at-task=START_AT
示例1:定义一个playbook任务来新增用户和组
定义一个yaml的模板
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/3c9cf9793ff84099b97ae1b597dc0c34.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/953b3fe151c748f0b810a8e5a8f0065b.jpg)
查查语法有没有错误,没有提示即表示语法应该没有问题。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/0792e02be76f4d0aba21bb3e41b19034.jpg)
测试运行看看,-C表示仅测试跑一边,但是不会实际操作
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/4d06479e407543a8813b016d932486fb.jpg)
也可以单独测试某些特定的选项
查看仅影响的主机
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/4c196fe0a1f54f51b71714f3409702cf.jpg)
查看运行哪些任务
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/3200a6345d504e5680d4afc8c35adb45.jpg)
查看哪个任务打标了,这里并没有任何任务打标记,后面再演示
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/187f1f7d357741e9839fbf43d892bbf8.jpg)
以上没有错误,开始正式运行该任务
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/739927aac76949749eb6cc26c6799582.jpg)
验证
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e5e5a02d89804e2bb4f7f26e0e16576d.jpg)
示例2:定义一个playbook任务来修改文件端口
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/646ee7d2b04442ef940de9d72147836b.jpg)
此步骤里面有安装httpd的安装包,其实此处有点多余,因为测试的两台主机均已经安装该服务,此处添加上去是为了演示效果,因为当生产环境中,假如存在一台服务器没有该安装包,那么次处就能帮我们安装上去,不然的话,漏了这一步,到后面查原因也挺麻烦的
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e593c4c9135d463fbcc85e0e4b2221fd.jpg)
检查语法问题
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/603068deb776442784e0d3b7cd57683b.jpg)
先从一台主机上面把httpd.conf文件拷问来编辑
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e7d18f92548e4d40bad45ad4126ae5bc.jpg)
修改httpd.conf文件
比如修改端口为8080,其他都为默认配置
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/bfb79cd4902947d0a6a369b3ef5de8ac.jpg)
首先备份好各自主机里面的配置文件,以防后面出错
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/5d4e6891cca643adae9fbbf4f6f1c0ee.jpg)
检查备份是否成功
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/16eeadf477554c05b5952c234cc9cbab.jpg)
测试运行web.yml,看看有没有问题,没有问题的话就正常运行
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/363f9f1398c44c90b23f707e25e30e07.jpg)
执行改文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ab93e43cfe1a4db996ce936f782a7ec4.jpg)
验证服务器端口打开没有,可以看见8080端口已经打开,实验成功。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/b491917cb4b14e4489c3a8ee4920bfb0.jpg)
Handlers的使用:由特定条件触发的Tasks;
格式:
tasks:
- name: TASK_NAME
module: arguments
notify: HANDLER_NAME
handlers:
- name: HANDLER_NAME
module: arguments
示例:参照上面的例子继续修改apache的端口
修改端口号为8090
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/b4383239e909427fa1d3d1fc438fd0bc.jpg)
修改原来的web.yml脚本实现操作
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/7e3eb53885b44520bee975aa1609f43d.jpg)
检测语法
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/21b79a66d6a4456f9f3832518df62517.jpg)
测试运行,可以看出,当复制文件过去的时候,会触发到restart httpd service的handlers任务,所以任务就重启了,而不是启动
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/f6889d390c4c46158f2b3f20071aea8f.jpg)
正式运行
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/66bb832e41944b85876b8cf288699f94.jpg)
验证结果,8090端口已经打开,实验成功
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c7e6c3b33c8a4576b63d286f21856da9.jpg)
tags:给指定的任务定义一个调用标识;
使用格式:
- name: NAME
module: arguments
tags: TAG_ID
示例:执行特定的tags
修改文件的端口为8088
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/18715586fb5a4a80b1a94307518d1480.jpg)
在此前的配置文件上面插入一个标签instconf
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e43c65fc831a43089e169359f1c64ea5.jpg)
检查语法
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/cd503d056e6c40c0bb93cc58c303ca42.jpg)
此处可以查看到该yml脚本有一个标签,影响着websrvs组
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/418f22bc53f54ee186467562cc88b16d.jpg)
测试运行
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/1e5f0dd5e86f4edf85dd87ce1dd31774.jpg)
正式运行一下,指定以instconf的标签运行,所以此处不会显示器其他多余的信息,包括安装httpd包和启动httpd服务
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/17e73f6b462841a79c427487330da859.jpg)
验证该结果
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/112f07b90dfe4ae8a20afba289687199.jpg)
此处也可以对同一个文件标记多个标签同时执行
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/611b2034731042a48ae00130980bce89.jpg)
测试运行,因为此处已经安装了httpd包和文件已经复制过去,所以都是绿色,此处就演示到这里,其他步骤可以参考上面的操作
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/589dc86723834565b59835cae857b15a.jpg)
Variables:变量
类型:
内建:
(1) facts
自定义:
(1) 命令行传递;
-e VAR=VALUE
(2) 在hosts Inventory中为每个主机定义专用变量值;
(a) 向不同的主机传递不同的变量 ;
IP/HOSTNAME variable_name=value
(b) 向组内的所有主机传递相同的变量 ;
[groupname:vars]
variable_name=value
(3) 在playbook中定义
vars:
- var_name: value
- var_name: value
(4) Inventory还可以使用参数:
用于定义ansible远程连接目标主机时使用的属性,而非传递给playbook的变量;
ansible_ssh_host
ansible_ssh_port
ansible_ssh_user
ansible_ssh_pass
ansible_sudo_pass
...
(5) 在角色调用时传递
roles:
- { role: ROLE_NAME, var: value, ...}
变量调用:
` var_name `
示例1:利用命令行传递变量来安装不同的包
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/0f92a2ed4fc34335aebd7201f895d2be.jpg)
此处` pkgname `表示为一个变量
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/2ad7aefd455a46439e565ec8cf506954.jpg)
检查一下语法,居然报错了,什么情况?仔细看了即便发现是漏了空格
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/90dfb5506e3443488649cac595e069e2.jpg)
加上空格
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/3ddaf831071b4c0ba31de5f40e9a0b0c.jpg)
再次检查,还是还是有报错的情况,各位不要慌,因为这只是因为还没有给变量赋值才会报的错,所以此处报错是很正常
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/204a38272acc442da1f18f82bab4a363.jpg)
给变量赋值再跑一遍,此时就不会报错
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/b1eb4e1b21774cd3adf21a4d91d931bd.jpg)
修改一下变量,发现也是正常的,此处68因为已经安装过vsftpd所以就不会执行,所以并不会changed
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/16c4bc18bbe74308a35603880c93165f.jpg)
示例2:在playbook中定义变量
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ced58a7553344c22853ec4e650d02a35.jpg)
测试,也没有问题的
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/eef5f8c622714322ac8ddb3ea043aa67.jpg)
思考?假如同时利用-e的参数传递一个变量的参数的话会怎么样?
测试结果如下,是-e传递的变量参数的优先级更高,这样的话能避免传递参数的时候,因为文本里面定义的优先级更高而出错?
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/5ed3f95c100e4e609a12ade7b090690e.jpg)
示例3:在hosts Inventory中为每个主机定义专用变量值
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/7b25c0d8da63443494f836ddbe29f3bc.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/8ea1b80636ed4a148f411abafe05b5e6.jpg)
删除掉文档里面原有的变量
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/247dff80cd8c489c8e52a4214ba1df2e.jpg)
测试,没有问题
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/bc637b78d0234e52a2f49957b0b689d6.jpg)
示例4:在hosts Inventory中为每个主机定义专用变量值的第二种方法
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/7b25c0d8da63443494f836ddbe29f3bc.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/1abe1548d61b48a9ac6191ee63f60426.jpg)
测试,也是可以的
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/14b1ade3b6604f58a3c9104b1c730d8b.jpg)
Templates:模板,文本文件,内部嵌套有模板语言脚本
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/d646cb23d1f9404ea7fb2d9861996bb6.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/00ea21b419164674b7144941ece25ef9.jpg)
语法:
字面量:
字符串:使用单引号或双引号;
数字:整数、浮点数;
列表:[item1, item2, ...]
元组:(item1, item2, ...)
字典:{key1:value1, key2:value2, ...}
布尔型:true/false
算术运算:
+, -, *, /, //, %, **
比较操作:
==, !=, >, <, >=, <=
逻辑运算:and, or, not
执行模板文件中的脚本,并生成结果数据流,需要使用template模块;
template:
-a " "
src=
dest=
mode=
onwer=
group=
注意:此模板不能在命令行使用,而只能用于playbook;
示例:利用templates模板来设置nginx的定义cpu的数量
首先利用ansible命令获取当前系统系统的cpu数量
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/9b7513ef734343f88025ee23d1182c08.jpg)
首先备份一下默认的文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/d7fcc45853a34ad4b202a20caa66e698.jpg)
首先在下面的主机传送一个配置文件过来
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/6f57224c79e4431781a40802dddf1dec.jpg)
编辑该文件,修改此处为上面利用ansible的setup模块获取的名称
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/cc5620b9005341c5ae4a99875cb49918.jpg)
重命名该文件为Jinja2格式后缀的文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/888ad894f39948fbad22425ba56f841b.jpg)
新建一个playbook文件,为了演示,建立一个ngxsrvs组,虽然看上去都一样。。。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/de396ff892a748d892b599d1c78ea008.jpg)
建立playbook文档
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c57e8aa8b6c54c2bab43b0a4a3834ee9.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/0dce71e5354b4b9b84fd65ad14bd2cfa.jpg)
此处为了演示效果,此处把原来的nginx包卸载掉
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/99d78fbae4a44f9dbe126da8e9f2ced5.jpg)
确认安装包卸载掉,并且服务没在线
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e0024852f84a4ae092ec81c317195890.jpg)
检查playbook的文件有没语法错误
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/f8017a3c698e476bb728283fea499a33.jpg)
测试运行,此处报错是因为找不到nginx的服务,所以应该是没有问题的
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/feb11d2795dd4e4497388a0e05fd2d86.jpg)
正式运行,没有问题
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/570173f7ad054b63819145fb535bf1d6.jpg)
查看一下端口是否已经打开
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/325ab399e87c41de931f288aeb4f353a.jpg)
重点检查一下cpu的变量是否有改变,这里可以看到,跟我们ansible_processor_vcpus的值是一样,这样符合我们预期,此处就展示完毕
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/58a291b0f0404539875908868f8240f6.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/67bafffb18a24086a731ed420e818da1.jpg)
条件测试:when语句在tasks中使用Jinja2的语法格式;
示例:利用Ansible条件测试在CentOS_6和CentOS_7的启动服务
这边首先增加一台ip为10.1.156.70的CentOS7的主机
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/98ba6e66ba964117a9ef119f4c3931f8.jpg)
然后我们利用setup模块的命令
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/bfce80c277bb40559a902b9781e30d5c.jpg)
在7的上面可以找到该行
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/f5e0ac8f09ae443ca32dd9edc6dc3655.jpg)
在6的上面可以找到该行
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/b1cbc1e62d76429cbbddd60973902bf4.jpg)
根据以上的信息,我们就可以创建一个基于条件判断的playbook文件test.yml
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/d1b83956de1541c490c1c9e0f8e22be5.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ea85bd58ea874b0fa9e68876f75a961c.jpg)
为了演示效果,实验前把CentOS6的nginx先卸载掉,此处70的报错只是因为ssh缺少那边没有提供公钥文件,此处就不再演示
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/7c2f2dafb9f0428eba6f3ab24f76bfb4.jpg)
检查playbook语法有没有问题
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/76c6f47a11f847089e1715c22b485aae.jpg)
测试运行,没有报错,可以看出当执行service nginx start命令时候,只有CentOS6的主机执行了命令,不过开始那里提示有skipping信息是为什么?CentOS7开始也提示有skipping信息?但是后面确实是执行成功了,下面正式运行该playbook看看效果。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/8484c9c3644b4544a44a27c7529a49c7.jpg)
正式运行,似乎没有报什么错误
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/8cb8dd4428c24581988537fcd7d46c73.jpg)
看看服务是否已经开启,此处可见80端口已经开发,应该是没有问题的,此处就不浏览主页做测试了
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/cf5b499b43284cdbb5ccfb4ac65c8500.jpg)
循环:迭代,需要重复执行的任务;
对迭代项的引用,固定变量名为"item”,使用with_item属性给定要迭代的元素;
元素:列表
字符串
字典
基于字符串列表给出元素示例:
示例:基于列表的方式安装多个安装包
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/87d0f3aa886c4be1b10648f9c1061a5c.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/3cb522f17ede41d3866684211ae1147a.jpg)
检查语法
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/2a6b8ac045b64a8589dc583ae0c77d5e.jpg)
测试运行,没有报错(这里就以69和70两台不同的版本的CentOS来做测试)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/9545d2ced09e4d5a90bc70f1c1e82842.jpg)
正式运行,69的机器报错了,看了一下原因,是下载php-mbstring的时候出错了,此处原因应该是虚拟挂载CentOS6.8的cd1导致的,挂载cd2应该就解决此问题,不过部分安装包应该是在cd1里面,所以小伙伴们最好找一个安全包都全的yum仓库
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/f1eb8752235b4be9b3db0dff7e195c18.jpg)
重新配置好yum仓库,并且把先前安装的先卸载掉,以配置实验
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/3e7753a5521f427dbeaf50edf17c547e.jpg)
此处可以看出来,由于69主机刚报错了一个,所以所有的包都没有安装,7上面倒是都已经安装过了
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c44a1d39edf54e9b9f1ebdb297d3dacf.jpg)
重新运行脚本,没有报错了
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/84975c1c24a8426fad9c5a3e1e957391.jpg)
验证,发现已经安装上了,此处就不再看其他安装包的安装情况了,应该没有大问题
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/5ea555e91c42420984b895833e88c53a.jpg)
基于字典列表给元素示例:
示例:创建指定的用户并属于指定的组
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/146c9909209d4c69b3e1176de4bdb2d6.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/363660f82a7d4befa2f14e41ca20804c.jpg)
检查语法
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/55975f4f108f42bfad0a7827c0ed249a.jpg)
测试运行,没有提示有任何变化?
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/a3a21434d270480abd6b8caca827c234.jpg)
正式运行,可以看见创建了对应的用户和组
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/4ec44cb656c8494da2f757fc501bf570.jpg)
验证,符合我们预期
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/20158c63959f48f8acce8ad77b41744f.jpg)
角色:roles
以特定的层级目录结构进行组织的tasks、variables、handlers、templates、files等;
role_name/
files/:存储由copy或script等模块调用的文件;
tasks/:此目录中至少应该有一个名为main.yml的文件,用于定义各task;其它的文件需要由main.yml进行“包含”调用;
handlers/:此目录中至少应该有一个名为main.yml的文件,用于定义各handler;其它的文件需要由main.yml进行“包含”调用;
vars/:此目录中至少应该有一个名为main.yml的文件,用于定义各variable;其它的文件需要由main.yml进行“包含”调用;
templates/:存储由template模块调用的模板文本;
meta/:此目录中至少应该有一个名为main.yml的文件,定义当前角色的特殊设定及其依赖关系;其它的文件需要由main.yml进行“包含”调用;
default/:此目录中至少应该有一个名为main.yml的文件,用于设定默认变量;
在playbook中调用角色的方法:
- hosts: HOSTS
remote_user: USERNAME
roles:
- ROLE1
- ROLE2
- { role: ROLE3, VARIABLE: VALUE, ...}
- { role: ROLE4, when: CONDITION }
示例:创建对应的服务目录下面的模版
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/4e3706e31d6c43ac9eb10918bce081e4.jpg)
首先创建对应的目录
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/de168ec1b93640eaa45cadcc7f2c6027.jpg)
确认一下目录是否正确
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/bab17ce9257040f6ba86e2eca4ebb03f.jpg)
首先准备一个安装包,放到nginx/file/目录下面
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/7d89a73ff23b4582a25f95aadc3c22f4.jpg)
新建一个nginx的task模板
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/f24d171a1bab42beb2597a6b468521dc.jpg)
大家可以发现此处的模板跟之前的不一样,比如说,开头没有了定义主机、用户、和task等,此处的task会自行查找/etc/ansible/roles/nginx/task/main.yml的任务(此处文件本身也是在task目录下面)。
再比如说,该处指定的copy命令的src=FILENAME也是相对路径,其绝对路径为/etc/ansible/roles/nginx/file/FILENAME。又比如说定义了notify但是这里并没有handlers,是因为此处定义了的notify的名字会自行去查看该目录下面即/etc/ansible/roles/nginx/handlers/main.yml里面的handlers。还有template那里,大家有没发现也是用的相对路径,此处绝对路径为在/etc/ansible/roles/nginx/template/nginx.conf.j2。所以大家清楚了吗?
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/346539ce155740d280fd690a9912c7df.jpg)
接着是定义/etc/ansible/roles/nginx/handlers/main.yml
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/6566284f09274e1b8e48401622fbba3c.jpg)
此处的文件就是用来承上面的notify里面为什么没有定义的handlers的原因,因为已经定义在../handlers/main.yml里面了。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/b7107b42c30643f8b1ef7bc16f1f29d5.jpg)
复制nginx.conf文件到templates目录下面为nginx.conf.j2
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/88750c08f16d42438a3f455db89a0379.jpg)
编辑里面定义的cpu数量,之前是2,所以此处我们也可以利用算数表达式来控制cpu的数量,比如此处-1,到时候看到的cpu数量应该是为1。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c7ce8606cdb54dbab11e2bcff254b1a9.jpg)
再复制/etc/nginx/conf.d/default.conf到nginx/templates/default.conf.j2
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/50c465f13fbc4a03983036d0774b9336.jpg)
然后编辑此文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c07dfefdebed497d9cd608977965803d.jpg)
编辑原来的端口号为一个变量值ngxport
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/591a43d6948343fdbfc27c5dcf6952bf.jpg)
此时需要重新编辑task/main.yml文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/238e5aac361f46699939b1da9b3921ab.jpg)
主要添加一下内容
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/96f9bd5f012b4cb685715743caf83387.jpg)
此时我们就可以定义变量文件了
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/aa45db9efe9f40eb9bc2b3c037e84ba9.jpg)
比如说定义ngxport的变量为8888
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/b63d3e7f865a42aa992dd3da8c6040cf.jpg)
此时所有的元素暂时都足够了,meta和default的文件夹在此处暂时用不上,然后我们在/etc/ansible/目录下面创建一个nginx.yml的文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/939b2260ff0a47ccb6425b9bd7725bc3.jpg)
注意此处的roles里面的nginx要在/etc/ansible.cfg文件里面有对应的设定
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/d74969a316aa4f559118c178efe47e86.jpg)
编辑查看ansible.cfg文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/3ab47741775b49a89b9ab0b2f0d6220d.jpg)
可以看见系统默认的roles路径也是在此处,所以我们去掉#号来启用它
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/fa7d6faa501646ea92c5ff3bf90c2775.jpg)
修改成如下
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/962d436006c641cca2b58dbef2de44ca.jpg)
以上都准备好了以后,检查一下nginx.yml语法,暂时并没有报错
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/5bd590dbcff64f11a8e2eba136422a6b.jpg)
然后测试运行,可以看见此处报错了,看了一下报错的原因,是因为找不到/tmp/nginx安装包,因为只是测试运行,并没有传送安装包到目标主机上面,所以此处报错是正常的可以不予理会。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/00d9888dc786431fbd4f2704da4967ce.jpg)
下面正式运行该脚本,此处报错了,原因看了一下,nginx安装包是el7版本的,在centos6上面并不能安装。以及handlers出问题了。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/adfca183e51a4d178c5015212db77251.jpg)
此处修改一下tasks/main.yml,以下红色内容为修改部分,意思就是,CentOS7系统从远程复制的安装包安装,CentOS6则直接从yum仓库源安装,6和7的nginx的配置文件应该是一样的,暂时先这么操作实验看看结果,并且先把CentOS7系统的nginx安装包删除掉,以重新演示效果。notify处的语法错误,此处补上。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/83ad59d2c0a746d784ef3ef81b7a6d5b.jpg)
修改完以上的内容,重新测试运行
可以看出来此处还是有报错内容,
第一个报错内容为找不到安装包,此处是正常的,因为安装包还是传过去(上一次运行的时候传送过去的安装包我已经删掉了,所以此处需要重传)
第二个报错内容为找不到nginx服务,此处也是正常的,因为nginx安装包还没有安装
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/6f705159a6354fe182fa8b0bc37ad25d.jpg)
正常重新运行一下nginx.yml脚本看看,发现已经没有报错的地方了
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c72b501382754c29a610801fe790158c.jpg)
验证结果,发现8888端口已经打开
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/2946c6d548cc4a4690d757d0cc26b4cd.jpg)
cpu数量的设置也跟我们之前配置的是一样的,实验到此结束
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/1e0863e95d304ccf8d8164c4ae61e8f5.jpg)
示例2:根据以上内容,修改端口号
当我们写好模板以后,需要修改端口号,也是非常容易的,而且我们也可以通过在nginx.yml上面通过roles传递变量
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/21fd21ad0f8940c396cc5e782d8fe133.jpg)
例如像以下这样子操作
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e2eb774cecd94f769646963d35438f89.jpg)
测试运行一下看看有没有错误,可以看见在复制配置文件和重启服务那里有了变化,这符合我们预期
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e9f119f3448d4492b65586dc5165a3cd.jpg)
正式运行一下看看,能正常运行
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/4cafd0f5687c47d3a11f2cd26e768471.jpg)
验证端口号是否修改成功,看到8080端口,表示操作没有问题
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/41479f21d52b4d1685fe2f3021e0e3c4.jpg)
以上是运行成功了,但是细心的同学会发现,这样所有程序都跑一遍也麻烦,所以我们可以用之前了解到的标签来执行特定的操作即可,也可以直接传递相应的变量。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/5d7a888746b84efe80d975022c6ad629.jpg)
直接传递参数测试运行,好像没有问题
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/a6460ea552b249e9ac43a8f6fdeddc79.jpg)
正式运行
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/5f12bde17b984ea58e3189185c0c44b7.jpg)
查看端口号是否正确,此处可以看见是我们定义的8099端口,测试成功
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/75d061d9e7a34bd3bc62c97ec6d2b1f8.jpg)
示例:实现httpd不同主机不同的端口号
首先先把定义的端口号先屏蔽掉
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/9038ec35ab084711a7400774b99d003c.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c9691c2dca6744d5865be5409a7daeb7.jpg)
编辑/etc/ansible/hosts文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/02288e6b868f41d8b226e92d96ce32e1.jpg)
定义对应的端口号,然后测试
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/30572cead34f411084e6c7de0b8eab7c.jpg)
然后记得把nginx.yml文件里面也改回来
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/4a007c68d0014250a83d24c4edfb3580.jpg)
这里直接运行就不先做测试了,不过一般同学们还是做好测试工作比较好
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/9671e515b0c64fc593cc7ded8679b0d2.jpg)
验证端口号,也符合我们预期
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ca52fd37f53c4e2493d8ef9fbee89720.jpg)
示例:在同一个yml配置文件里面运行两个服务模板程序
这里以memcached为例,首先复制memcached的配置文件到对应的templates目录下来为.j2的文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/db3b6068d3394ee5891c5e40786c97fd.jpg)
memcached服务是依靠设置内存参数来定义的,所以我们得首先用ansible来确认系统的内存变量参数值是什么,并且通过以下图可以看见两个系统参数都是一致的。
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ede6f91e5b9848019f97453bfc850a2c.jpg)
编辑memcached.j2文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c158ebe28b5d4554ab531c2931160824.jpg)
定义变量参数
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ff4494e91da248ee988cee00d7324f02.jpg)
改成
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/9b681c24647e42a9b1bbae492959b0c8.jpg)
开始定义memcached的任务文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/68871f811a474f999ccb18a1c86e2c67.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/74e0d9f6c0be47199621b496f6e8aae5.jpg)
定义handlers文件
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/95a9ba698acc4e72979ae2150af8d730.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/4dda386d1d054c19bb99e0b9c4b40c2a.jpg)
把memcached定义在ngnix.yml文件一同运行
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/2046379a490c489fb9199060382211c0.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/1a5e8f88a17a434d8d38d8f44ec2a257.jpg)
测试运行,只是安装包还没有安装,提示的错误都问题不大,是正常的
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/382d0178a64c42c7b4514b1c753fdf8a.jpg)
正式运行
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/e955f964bdb947d29ccf8f030f027e7d.jpg)
验证服务是否开启,且是否设置好预期可用内存
可以看见11211端口已经打开
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/4705dec42b184b9e86267b4f57f824af.jpg)
查看可用内存,原来的数值是970~980多,这里200多,符合除以4的预期效果
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/9d302f48358e4c69a240c0b492d0caa8.jpg)
示例:根据不同的系统安装mysql包
首先定义一个tasks的模板
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/5a492cbf8abc43498a9811207e6472aa.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/b4e99af0e9f64e1d8aa885f664cedd14.jpg)
定义一个yaml调用角色脚本
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/1c802bf472fd43158c848b3a963e52ef.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/26b4751cc0274c2b8417febb0a747240.jpg)
设置hosts文件添加dbsrvs组
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/83411b8fe3e54c4f92495012eabd4b6b.jpg)
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/03ad098b06fc4503ad6864f7b79b0fd5.jpg)
测试语法
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/0d55f1ebd27948f2a14308e88de9636a.jpg)
测试运行调用角色脚本db.yml,应该没有大问题
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/c74ea992d95f4c1b8eb830c119072c5b.jpg)
正式运行,没有报任何错误
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/ccaec65b1bcc492f86d02d8a721a072e.jpg)
验证服务是否已经开启
可以看见mysql和mariadb服务均已经开启
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/a1477ce7bea74acdbfeabb25267e4603.jpg)
写在最后,关于ansible的能最多控制几台主机
此处是在配置文件里面定义的,默认是5台主机,如果把主机的控制的主机调大,估计也要相对应性能的主机当ansible服务器
![看完这243张图片,轻松掌握 Ansible !](https://image.cha138.com/20210425/046e8b26501641b0911e5976040fe10c.jpg)
下面总结几个小点:
1、 ansible的playbook.yml文件要求的格式比较严格,有时候少了几个空格,或者空格位置不妥当的时候,系统均默认此格式为错误,所以需要小心
2、 有时候输入错了ansibile不能识别的错误,用- - syntax-check 或者 –check 测试文件的时候并不会提示有任何提示,需要实际运行才能会报错。
3、 有一次写playbook.yml文件的时候,检查过是没有问题,但是测试一直出问题,后来把所有重写一遍就好,也可能是哪里错了自己没看见。
来源:http://weiweidefeng.blog.51cto.com/1957995/1895261
- MORE | 往期精彩文章 -
长按二维码关注民工哥技术之路
-------------------------------
感谢大家的阅读,下面是一个抽奖链接,点击链接进去参与抽奖吧,2019年6月9日21:59开奖,感谢大家的支持!
正在看的你,点这里有惊喜哦~
以上是关于看完这243张图片,轻松掌握 Ansible !的主要内容,如果未能解决你的问题,请参考以下文章