ansible-playbook用法
一、playbook用法
1、playbook的执行文件为YAML语言编写,所以文件名为xxx.yml。YAML语法可以参考https://docs.ansible.com/ansible/latest/reference_appendices/YAMLSyntax.html#id1
2、下面以安装httpd软件来作讲解
示例playbook:
[root@localhost test]# cat httpd.yml
--- #文件起始行,也可以省略。但是不建议省略
- hosts: docker #docker表示远程执行这个yml文件的主机组,这里也可以指定对应的主机ip,或者正则表达
remote_user: root #远程执行命令的用户
vars: # vars以下为参数,可根据架构来选择是否有参数
pkg: httpd # 定义变量名为pkg,值为httpd,后续可以使用{{ pkg }}来引用
tasks: # tasks后续跟执行的任务
- name: uninstall httpd # 自定义任务名
yum: name={{ pkg }} state=absent # 任务执行命令, 这里表示用yum模块来卸载 httpd软件, {{ pkg }}引用vars中已经定义的变量,state表示对软件的操作,这里表示卸载
tags: unhttpd # tags为标签,任务都可以加上标签名,通过tags我们可以执行特定的任务,例如:ansible-playbook -t unhttpd httpd.yml 表示执行http.yml中tags为unhttpd的任务
- name: install http
yum: name={{ pkg }} state=installed #这里表示用yum模块来安装 httpd软件
tags: httpd
- name: copy cfg
copy: src=/opt/test/httpd.conf dest=/etc/httpd/conf/ #这里表示调用copy模块来将src的文件copy到目的地dest指定的位置
notify: restart service # notify 可以理解为触发器,与handlers配合起来使用。 当notify标注的任务被成功执行后,就会触发对应的handlers任务执行
tags: copy
- name: start service
service: name=httpd state=started enabled=yes
tags: httpd
handlers: #handlers和notify配合使用
- name: restart service # 任务名需要和notify名称一致,多个相同的任务可以使用同一个notify名称来触发同一个handlers任务,handlers任务可以为多个
service: name=httpd state=restarted
3、执行playbook
-C表示执行检查,不会对系统做改变,会完整的运行所有任务,检查playbook任务是否正确:
#ansible-playbook -C httpd.yml
执行playbook,根据任务顺序执行,系统会根据任务有所变化:
# ansible-playbook httpd.yml
执行结果说明:
绿色: 执行成功,不需要做改变(这里好像并不是一定不改变)
红色: 执行失败
黄色: 执行成功,并且系统有变化
执行结果颜色可以通过ansible的配置文件进行私人定制。
4、关于模块的使用
ansible-doc --list #可以列出所有可使用模块,核心模块:http://ansible.com.cn/docs/modules_core.html 额外模块:http://github.com/ansible/ansible-modules-extras
ansible-doc -s Module_Name #查询模块的使用方法 ,如: ansible-doc -s yum 查询yum模块的使用方法
ansible-doc Module_Name #更详细的展示模块的使用,和linux中的man手册类似
5、关于参数的定义
参数优先级: 命令行>局部>全局
♦ 通过命令指定,优先级最高
ansible-playbook -e varname=value xxx.yml
♦ ansilbe setup facts远程主机的多有变量都可以直接使用可以在执行ansible命令的时候给与变量值
ansible hostip -m setup #可以查询到ansible系统的一些信息,其中就包括可以直接使用的变量
♦ 在/etc/ansible/hosts中定义
普通变量;主机组中单独定义,优先级高于公共变量
公共(组)变量:针对主机组中所有主机定义统一变量
[docker]
172.17.0.2 http_port=80 #普通变量
172.17.0.3 http_port=90
[docker:vars]
http_port=100 #公共变量
♦ 在playbook中定义
vars:
- var1: value1
- var2: value2
♦ 在role中定义
需要一个固定的vars目录来存放编辑变量的文件,后续roles的使用中会讲到
ansible-playbook用法的更多相关文章
- ansible playbook模式及语法
一.什么是playbook及其组成 什么是playbook playbook 翻译过来就是"剧本" playbook的组成 play:定义的是主机的角色 task:定义的是具体执行 ...
- ansible playbook详解
ansible playbook是由yml语法书写,结构清晰,可读性强,所以必须掌握yml基础语法 语法 描述 缩进 YAML使用固定的缩进风格表示层级结构,每个缩进由两个空格组成,不能使用tabs键 ...
- 02 . Ansible高级用法(运维开发篇)
自动化任务简介 假设我们要在10台linux服务器上安装一个nginx服务,手动是如何做的? # 第一步, ssh登录NUM(1,n)服务器 # 第二步,输入对应服务器密码 # 第三步,执行命令: y ...
- (三)ansible playbook
一,YAML语法 YAML的语法和其他高阶语言类似并且可以简单表达清单.散列表.标量等数据结构.(列表用横杆表示,键值对用冒号分割,键值对里又可以嵌套另外的键值对) YAML文件扩展名通常为.yaml ...
- Ansible playbook API 开发 调用测试
Ansible是Agentless的轻量级批量配置管理工具,由于出现的比较晚(13年)基于Ansible进行开发的相关文档较少,因此,这里通过一些小的实验,结合现有资料以及源码,探索一下Ansible ...
- ansible playbook实践(四)-如何调试写好的playbook文件
有时,我们写了一个长长,功能很强悍的yaml文件,但是,我们有可能会担心,写的yaml文件是否正确,是否有漏洞危机,毕竟是要修改线上的机器,那么,有可能我们可以从以下几个检查维度来进行,确保在大规模应 ...
- ansible playbook批量改ssh配置文件,远程用户Permission denied
最近手里的数百台服务器需要改/etc/ssh/sshd_config的参数,禁止root直接登陆,也就是说 [root@t0 ~]# cat /etc/ssh/sshd_config | grep R ...
- ansible笔记(11):初识ansible playbook(二)
ansible笔记():初识ansible playbook(二) 有前文作为基础,如下示例是非常容易理解的: --- - hosts: test211 remote_user: root tasks ...
- ansible笔记(10):初识ansible playbook
ansible笔记():初识ansible playbook 假设,我们想要在test70主机上安装nginx并启动,我们可以在ansible主机中执行如下3条命令 ansible test70 -m ...
- Ansible playbook 批量修改服务器密码 先普通后root用户
fsckzy Ansible playbook 批量修改服务器密码 客户的需求:修改所有服务器密码,密码规则为Rfv5%+主机名后3位 背景:服务器有CentOS6.7,SuSE9.10.11,r ...
随机推荐
- FreeNas搭建踩坑指南(三)
0x00 Dell R730 无法编辑阵列卡Raid FreeNas和Windows Server都做成了uefi启动,装之前删掉了数据盘配置,系统装好后重启发现无法进入阵列卡编辑 0x01 解决方案 ...
- Ocelot + Consul + Registrator 基于Docker 实现服务发现、服务自动注册
目录 1. Consul集群搭建 1.1 F&Q Consul官方推荐的host网络模式运行 2. Registrator服务注册工具 2.1 F&Q Registrator悬挂服务 ...
- Java初学习-常见单词
implements 实行/实现 用于实现接口(interface) extends 延伸/扩展 用于类的继承 container 容 ...
- 一起学Android之ProgressBar
本文简述在Android开发中进度条(ProgressBar)的常见应用,仅供学习分享使用. 概述 在Android开发中,进度条的使用场景有很多,如播放电影时可拖动的观看进度条,评分时使用的评分条, ...
- Websocket-Sharp获取客户端IP地址和端口号
//OnOpen事件 protected override void OnOpen() { string IPAddress = base.Sessions.Sessions.First().Cont ...
- Webdriver之API详解(1)
说明 Webdriver API详解,基于python3,unittest框架,driver版本和浏览器自行选择. 本内容需要对python3的unittest框架有一个简单的了解,这里不再赘述,不了 ...
- ajax实现用户登陆,退出,java做后端
最近http老师布置了个任务,用cookie完成登陆,退出.Http老师讲的是node.js写后端,由于自己还是擅长java些,还是用Java做了. 以前跟着教程写过一个网站,当初是用jsp+serv ...
- 【css】图片垂直水平居中
一.已知宽高的图片实现垂直水平居中 1.借助margin-top负边距实现垂直居中 <!DOCTYPE html> <html> <head> <meta c ...
- 【续】5年后,我们为什么要从 Entity Framework 转到 Dapper 工具?
前言 上一篇文章收获了 140 多条评论,这是我们始料未及的. 向来有争议的话题都是公说公的理,婆说婆的理,Entity Framework的爱好者对此可以说是嗤之以鼻,不屑一顾,而Dapper爱好者 ...
- 实现Kubernetes跨集群服务应用的高可用
在Kubernetes 1.3版本,我们希望降低跨集群跨地区服务部署相关的管理和运营难度.本文介绍如何实现此目标. 注意:虽然本文示例使用谷歌容器引擎(GKE)来提供Kubernetes集群,您可以在 ...