一、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用法的更多相关文章

  1. ansible playbook模式及语法

    一.什么是playbook及其组成 什么是playbook playbook 翻译过来就是"剧本" playbook的组成 play:定义的是主机的角色 task:定义的是具体执行 ...

  2. ansible playbook详解

    ansible playbook是由yml语法书写,结构清晰,可读性强,所以必须掌握yml基础语法 语法 描述 缩进 YAML使用固定的缩进风格表示层级结构,每个缩进由两个空格组成,不能使用tabs键 ...

  3. 02 . Ansible高级用法(运维开发篇)

    自动化任务简介 假设我们要在10台linux服务器上安装一个nginx服务,手动是如何做的? # 第一步, ssh登录NUM(1,n)服务器 # 第二步,输入对应服务器密码 # 第三步,执行命令: y ...

  4. (三)ansible playbook

    一,YAML语法 YAML的语法和其他高阶语言类似并且可以简单表达清单.散列表.标量等数据结构.(列表用横杆表示,键值对用冒号分割,键值对里又可以嵌套另外的键值对) YAML文件扩展名通常为.yaml ...

  5. Ansible playbook API 开发 调用测试

    Ansible是Agentless的轻量级批量配置管理工具,由于出现的比较晚(13年)基于Ansible进行开发的相关文档较少,因此,这里通过一些小的实验,结合现有资料以及源码,探索一下Ansible ...

  6. ansible playbook实践(四)-如何调试写好的playbook文件

    有时,我们写了一个长长,功能很强悍的yaml文件,但是,我们有可能会担心,写的yaml文件是否正确,是否有漏洞危机,毕竟是要修改线上的机器,那么,有可能我们可以从以下几个检查维度来进行,确保在大规模应 ...

  7. ansible playbook批量改ssh配置文件,远程用户Permission denied

    最近手里的数百台服务器需要改/etc/ssh/sshd_config的参数,禁止root直接登陆,也就是说 [root@t0 ~]# cat /etc/ssh/sshd_config | grep R ...

  8. ansible笔记(11):初识ansible playbook(二)

    ansible笔记():初识ansible playbook(二) 有前文作为基础,如下示例是非常容易理解的: --- - hosts: test211 remote_user: root tasks ...

  9. ansible笔记(10):初识ansible playbook

    ansible笔记():初识ansible playbook 假设,我们想要在test70主机上安装nginx并启动,我们可以在ansible主机中执行如下3条命令 ansible test70 -m ...

  10. Ansible playbook 批量修改服务器密码 先普通后root用户

    fsckzy   Ansible playbook 批量修改服务器密码 客户的需求:修改所有服务器密码,密码规则为Rfv5%+主机名后3位 背景:服务器有CentOS6.7,SuSE9.10.11,r ...

随机推荐

  1. Android 跳转权限设置界面的终极方案

    转载请标明出处,维权必究:https://www.cnblogs.com/tangZH/p/10338377.html 有时候APP需要获取某些权限,要让用户手动打开,那么问题来了,若是直接提醒用户出 ...

  2. datatable的部分问题处理(动态定义列头,给某行添加事件,初始显示空数据)

    一.动态定义列头 在ajax中,用datatable再去重新配置列头,当然传回的数据中,要有对应放列头的键值对 我自定义了Mock数据,用于前端自己交互. 其中,rowdata用于存放传回的数据,co ...

  3. .NET Core 学习笔记2——管理nuget包

    .NET Core 基于Nuget包.它是一个.nupkg后缀的zip文件. 工具 dotnet 工具 vs2017 的程序包管理控台 这两个工具都可以用命令行来下载安装,更新,上传包(上传要先在网站 ...

  4. 卸载windows补丁

    wusa /uninstall /kb: wusa /uninstall /kb: 和某些应用软件冲突时,需要将上述补丁卸载.

  5. SQL Server数据库文件与文件组总结

    文件和文件组概念 关于文件与文件组,简单概括如下,详情请参考官方文档"数据库文件和文件组Database Files and Filegroups"或更多相关资料: 数据文件概念: ...

  6. [转载]——说说IO

    本文转载自"和你在一起"的"说说IO"系列文章https://pengjiaheng.iteye.com/,总共分为8篇,特意整理.收录在此,支持原创.尊重原创 ...

  7. HDFS深度历险 之 从客户端逻辑看HDFS写入机制

    说明 除了标注之外,本文纯属原创,转载请注明出处:https://www.jianshu.com/p/ea6ef5f5b868, https://www.cnblogs.com/monkeyteng/ ...

  8. 初步了解PE分析

    尝试编写代码获取PE文件的信息. 首先使用 CreateFile打开一个PE文件并返回一个用于访问该对象的handle. HANDLE CreateFile( LPCTSTR lpFileName, ...

  9. python之三行代码发送邮件

    (1)首先进入cmd,输入pip install yagmail (2)思路:1 .连接服务器:yagmail.SMTP(邮箱账号,邮箱密码,邮箱服务器地址,邮箱服务器端口) 2 .准备正文内容:co ...

  10. Chrome 清除当前网站下的缓存

    打开开发者工具(F12),选择 Network--Disable cache 即可.需要清除某网站缓存时 F12 打开开发者工具就会自动清除这个网站的缓存,而不必清除所有网站的缓存了. 如评论中大佬所 ...