本节内容:

  • ansible playbook介绍
  • ansible playbook基础组件
  • playbook中使用变量

一、ansible playbook介绍

playbook是由一个或多个“play”组成的列表(剧本是由多出戏组成的)。play的主要功能在于将事先归并为一组的主机装扮成事先通过ansible中的task定义好的角色。从根本上来讲,所谓task无非是调用ansible的一个module。将多个play组织在一个playbook中,即可以让它们联同起来按事先编排的机制同唱一台大戏。下面是一个简单示例。

  1. - hosts: webnodes
  2. vars:
  3. http_port: 80
  4. max_clients: 256
  5. remote_user: root
  6. tasks:
  7. - name: ensure apache is at the latest version
  8. yum: name=httpd state=latest
  9. - name: ensure apache is running
  10. service: name=httpd state=started
  11. handlers:
  12. - name: restart apache
  13. service: name=httpd state=restarted

其中,tasks是一个一个任务。

二、ansible playbook基础组件

Playbooks结构:

  • Tasks:任务,即调用模块完成的某操作。
  • Variables:变量
  • Templates:模板
  • Handlers:处理器,指的是在某条件满足时能够触发完成的功能,或者说是由某事件触发执行的操作
  • Roles:角色。

1. Hosts和Users

playbook中的每一个play的目的都是为了让某个或某些主机以某个指定的用户身份执行任务。hosts用于指定要执行指定任务的主机,其可以是一个或多个由冒号分隔主机组;remote_user则用于指定远程主机上的执行任务的用户。如上面示例中的

  1. - hosts: webnodes
  2. remote_user: root

不过,remote_user也可用于各task中。也可以通过指定其通过sudo的方式在远程主机上执行任务,其可用于play全局或某任务;此外,甚至可以在sudo时使用sudo_user指定sudo时切换的用户。

  1. - hosts: webnodes
  2. remote_user: mageedu
  3. tasks:
  4. - name: test connection
  5. ping:
  6. remote_user: mageedu
  7. sudo: yes

比如写一个最简单的playbook,里面写了两个play,一个play是在nginx组的主机上都创建一个nginx组,nginx用户,另一个play是复制一个文件到mysql组的主机上:

  1. [root@node1 ~]# vim nginx.yml
  2. - hosts: nginx
  3. remote_user: root
  4. tasks:
  5. - name: create nginx group
  6. group: name=nginx system=yes gid=208
  7. - name: create nginx user
  8. user: name=nginx uid=208 group=nginx system=yes
  9. - hosts: mysql
  10. remote_user: root
  11. tasks:
  12. - name: copy file to mysql hosts
  13. copy: src=/etc/inittab dest=/tmp/inittab.ans

查看ansible-playbook的使用方法:

  1. [root@node1 ~]# man ansible-playbook

运行playbook:

  1. [root@node1 ~]# ansible-playbook nginx.yml

2. 任务列表(Tasks)和action

play的主体部分是task list。task list中的各任务按次序逐个在hosts中指定的所有主机上执行,即在所有主机上完成第一个任务后再开始第二个。在运行自下而下某playbook时,如果中途发生错误,所有已执行任务都可能回滚,因此,在更正playbook后重新执行一次即可。(因为具有幂等性)

task的目的是使用指定的参数执行模块,而在模块参数中可以使用变量。模块执行是幂等的,这意味着多次执行是安全的,因为其结果均一致。

每个task都应该有其name,用于playbook的执行结果输出,建议其内容尽可能清晰地描述任务执行步骤。如果未提供name,则action的结果将用于输出。

定义task的可以使用“action: module options”(这个在较新版本上才能执行)或“module: options”的格式,推荐使用后者以实现向后兼容。如果action一行的内容过多,也可以使用在行首使用几个空白字符进行换行。

  1. tasks:
  2. - name: make sure apache is running
  3. service: name=httpd state=running

在众多模块中,只有command和shell模块仅需要给定一个列表而无需使用“key=value”格式,例如:

  1. tasks:
  2. - name: disable selinux
  3. command: /sbin/setenforce 0

如果命令或脚本的退出码不为零,可能会阻止playbook继续往下执行可以使用如下方式替代:

  1. tasks:
  2. - name: run this command and ignore the result
  3. shell: /usr/bin/somecommand || /bin/true

也就是说这个命令失败也是要继续往下走的,就是失败了但不要影响下面的操作。或者使用ignore_errors来忽略错误信息:

  1. tasks:
  2. - name: run this command and ignore the result
  3. shell: /usr/bin/somecommand
  4. ignore_errors: True

3. handlers

用于当关注的资源发生变化时采取一定的操作。

“notify”这个action可用于在每个play的最后被触发,这样可以避免多次有改变发生时每次都执行指定的操作,取而代之,仅在所有的变化发生完成后一次性地执行指定操作。在notify中列出的操作称为handler,也即notify中调用handler中定义的操作。

  1. - name: template configuration file
  2. template: src=template.j2 dest=/etc/foo.conf
  3. notify:
  4. - restart memcached
  5. - restart apache

handler是task列表,这些task与前述的task并没有本质上的不同。

  1. handlers:
  2. - name: restart memcached
  3. service: name=memcached state=restarted
  4. - name: restart apache
  5. service: name=apache state=restarted

【举例】:比如有个配置apache的playbook,然后利用这个来说明handlers。

1.先创建一个apache.yml,里面定义play安装启动apache

  1. [root@node1 ~]# vim apache.yml
  2. - hosts: mysql
  3. remote_user: root
  4. tasks:
  5. - name: install httpd package
  6. yum: name=httpd state=latest
  7. - name: install configuration file for httpd
  8. copy: src=/root/conf/httpd.conf dest=/etc/httpd/conf/httpd.conf
  9. - name: start httpd service
  10. service: enabled=true name=httpd state=started
  11. [root@node1 ~]# ansible-playbook apache.yml

2.假如说某个时刻httpd.conf发生改变了,比如说不再监听在80,而是监听在8080端口,其他没变。修改/root/conf/httpd.conf,把端口改成8080,再执行这个playbook:

  1. [root@node1 ~]# ansible-playbook apache.yml

到mysql组所在的主机172.16.7.153上查看端口,发现监听端口仍然是80:

  1. [root@node3 ~]# ss -tnlp

3.一个程序的配置文件发生了改变,那么程序应该重读配置文件才对。然而默认情况下,你多次唱同一个剧本,如果那个task此前执行过,为了保证幂等性,它是不会再被执行。handlers就是为了解决这种问题而生的。Handlers也是任务,但它不是上来就执行的,只有某个条件满足时才会执行。所以我们去修改apache.yml:

  1. - hosts: mysql
  2. remote_user: root
  3. tasks:
  4. - name: install httpd package
  5. yum: name=httpd state=latest
  6. - name: install configuration file for httpd
  7. copy: src=/root/conf/httpd.conf dest=/etc/httpd/conf/httpd.conf
  8. notify:
  9. - restart httpd
  10. - name: start httpd service
  11. service: enabled=true name=httpd state=started
  12. handlers:
  13. - name: restart httpd
  14. service: name=httpd state=restarted

修改/root/conf/httpd.conf,把端口改成8090,再执行这个playbook:

  1. [root@node1 ~]# ansible-playbook apache.yml

到mysql组所在的主机172.16.7.153上查看端口,发现监听端口改变了,变成了8090:

三、playbook中使用变量

  1. - hosts: mysql
  2. remote_user: root
  3. vars:
  4. - package: httpd
  5. tasks:
  6. - name: install httpd package
  7. yum: name={{ package }} state=latest
  8. - name: install configuration file for httpd
  9. copy: src=/root/conf/httpd.conf dest=/etc/httpd/conf/httpd.conf
  10. notify:
  11. - restart httpd
  12. - name: start httpd service
  13. service: enabled=true name=httpd state=started
  14. handlers:
  15. - name: restart httpd
  16. service: name=httpd state=restarted

【注意】:playbook中能使用的变量不仅仅是这里定义的变量,而是可以使用ansible中定义的所有变量。例如:

  1. [root@node1 ~]# ansible 172.16.7.152 -m setup

另外,在inventory中定义的变量也可以在playbook中调用。例如:

  1. [root@node1 ~]# vim /etc/ansible/hosts

ansible入门四(Ansible playbook基础组件介绍)的更多相关文章

  1. Ansible playbook基础组件介绍

    本节内容: ansible playbook介绍 ansible playbook基础组件 playbook中使用变量 一.ansible playbook介绍 playbook是由一个或多个“pla ...

  2. Ansible入门篇:playbook的使用

    playbooks介绍 playbooks是 一个不同于使用Ansible命令行执行方式的模式,其功能更强大灵活.简单来说,playbook是一个非常简单的配置管理和多主机部署系统,不同于任何已经存在 ...

  3. Netty快速入门(09)channel组件介绍

    书接上回,继续介绍组件. ChannelHandler组件介绍 ChannelHandler组件包含了业务处理核心逻辑,是由用户自定义的内容,开发人员百分之九十的代码都是ChannelHandler. ...

  4. Ext学习-基础组件介绍

    1.目标    学习对象获取,组件基础,事件模型以及学习ExtJS中的基础组件的应用. 2.内容   1.对象获取   2.组件原理以及基础   3.事件模型   4.常用组件的介绍 3.学习步骤 1 ...

  5. Ansible系列(四):playbook应用和roles自动化批量安装示例

    Ansible系列文章:http://www.cnblogs.com/f-ck-need-u/p/7576137.html playbook是ansible实现批量自动化最重要的手段.在其中可以使用变 ...

  6. 四、OpenStack—glance组件介绍与安装

    一.glance介绍 Glance是Openstack项目中负责镜像管理的模块,其功能包括虚拟机镜像的查找.注册和检索等. Glance提供Restful API可以查询虚拟机镜像的metadata及 ...

  7. Netty快速入门(08)ByteBuf组件介绍

    前面的内容对netty进行了介绍,写了一个入门例子.作为一个netty的使用者,我们关注更多的还是业务代码.也就是netty中这两种组件: ChannelHandler和ChannelPipeline ...

  8. 阶段3 3.SpringMVC·_01.SpringMVC概述及入门案例_07.入门案例中使用的组件介绍

    这里配置上注解的支持,相当于配置了上面的前端控制器.处理映射器这两个

  9. RabbitMQ系列(二)--基础组件

    声明:对于RabbitMQ的学习基于某课网相关视频和<RabbitMQ实战指南>一书,后续关于RabbitMQ的博客都是基于二者 一.什么是RabbitMQ RabbitMQ是开源代理和队 ...

随机推荐

  1. XDU 1109

    #include<stdio.h> #define N 10007 #define maxn 1000005 int dp[maxn]; int main() { dp[]=,dp[]=, ...

  2. 本地idea开发mapreduce程序提交到远程hadoop集群执行

    https://www.codetd.com/article/664330 https://blog.csdn.net/dream_an/article/details/84342770 通过idea ...

  3. Maven 在 IntelliJ IDEA 中的使用

    一.概述 Maven 为构建软件,与 Gradle 类似,也能以插件的方式在 IntelliJ IDEA 中得到使用. 同样地,你也可以配置环境变量,这样就能够在命令行中进行操作了. 二.使用方式 其 ...

  4. iOS知识点整理

    1.宏定义 #define  #   ## a. 后面一个#是转成字符串 b. 后面## 是连接的作用 2. __attribute__ 常用的 __attribute__(( constructor ...

  5. Js 将 Date 转化为指定格式的String

    // 对Date的扩展,将 Date 转化为指定格式的String // 月(M).日(d).小时(h).分(m).秒(s).季度(q) 可以用 1-2 个占位符, // 年(y)可以用 1-4 个占 ...

  6. cordova 插件

    1.移动端WebApp开发,如何实现状态栏沉浸式效果? cordova-plugin-fullscreen 2. cordova热更新插件-不发布应用市场动态更新APP源码 https://githu ...

  7. 20145329 《Java程序设计》实验五总结

    实验内容: 1.用老师代码编写,实现服务器与客户端. 2.客户端与服务器连接 3.客户端中输入明文,利用DES算法加密,DES的秘钥用RSA公钥密码中服务器的公钥加密,计算明文的Hash函数值,一起传 ...

  8. 20144303 《Java程序设计》第七周学习总结

    20144303 <Java程序设计>第七周学习总结 教材学习内容总结 第十二章 Lambda Lambda表达式中this的参考对象以及toString()的接受者,是来自Lambda的 ...

  9. Linux文件系统学习(一)之相关概念⭐⭐⭐

    “一切皆是文件”是 Unix/Linux 的基本哲学之一.不仅普通的文件,目录.字符设备.块设备.套接字等在 Unix/Linux 中都是以文件被对待:它们虽然类型不同,但是对其提供的却是同一套操作界 ...

  10. PHP设计模式(三):抽象工厂模式