Playbooks简介

  • 关于Playbooks

  • Playbook简单示例

  • 基本组成

  1. 主机和用户

  2. 任务列表

  • Handlers: 配置更改时运行操作

  • 执行Playbook

  • Ansible-Pull

  • Linting playbooks

  • 其它的playbook确认选项

关于Playbooks

与ad-hoc模式相比,playbook是使用ansible的完全不同的方式,并且功能特别强大。

playbook是真正简单的配置管理和多机部署系统的基础,非常适合部署复杂的应用程序。

剧本可以声明配置,但是它们也可以编排任何有序步骤,即使不同的步骤必须在特定顺序的机器之间来回跳动也是如此。他们可以同步或异步启动任务。

ansible-examples资料库中,还有一些完整的剧本,说明了许多这些技术 。

Playbook简单示例

playbook用YAML编写。

每个playbooks可以有一个或多个playbook组成

verify-apache.yml仅包含一部剧本:

---
- hosts: webservers
vars:
http_port: 80
max_clients: 200
remote_user: root
tasks:
- name: ensure apache is at the latest version
yum:
name: httpd
state: latest
- name: write the apache config file
template:
src: /srv/httpd.j2
dest: /etc/httpd.conf
notify:
- restart apache
- name: ensure apache is running
service:
name: httpd
state: started
handlers:
- name: restart apache
service:
name: httpd
state: restarted

Playbooks也可以包含多个plays,可能首先针对Web服务器,然后针对数据库服务器的剧本。例如:

---
- hosts: webservers
remote_user: root tasks:
- name: ensure apache is at the latest version
yum:
name: httpd
state: latest
- name: write the apache config file
template:
src: /srv/httpd.j2
dest: /etc/httpd.conf - hosts: databases
remote_user: root tasks:
- name: ensure postgresql is at the latest version
yum:
name: postgresql
state: latest
- name: ensure that postgresql is started
service:
name: postgresql
state: started

基本组成

  1. 主机和用户

对于每个playbook都可以选择在哪些机器上使用哪个用户完成任务。

---
- hosts: webservers
remote_user: root

也可以为每个任务定义远程用户:

---
- hosts: webservers
remote_user: root
tasks:
- name: test connection
ping:
remote_user: yourname

还可以使用其他特权升级方法,例如su:

---
- hosts: webservers
remote_user: yourname
become: yes
become_method: su

如果您需要为sudo指定密码,请ansible-playbook使用--ask-become-pass或运行-K

还可以控制主机的运行顺序。默认值是遵循hosts存提供的顺序.

  1. 任务列表

每个任务的目标是执行带有特定参数的模块。变量可以在模块的参数中使用。

模块应该是幂等的,也就是说,按顺序运行一个模块多次应具有与仅运行一次相同的效果。实现幂等的一种方法是让模块检查是否已达到其所需的最终状态,如果已经达到该状态,则不执行任何操作即可退出。如果剧本使用的所有模块都是幂等的,则剧本本身很可能是幂等的,因此重新运行剧本应该是安全的.

基本的任务语法:

tasks:
- name: make sure apache is running
service:
name: httpd
state: started

command和shell模块关心返回码,因此,如果您有一个成功退出码不为零的命令,则可能需要这样做:

tasks:
- name: run this command and ignore the result
shell: /usr/bin/somecommand
ignore_errors: True

定义变量

tasks:
- name: create a virtual host file for {{ vhost }}
template:
src: somefile.j2
dest: /etc/httpd/conf.d/{{ vhost }}

Notify和Handlers

Notify写在tasks的最后面,它只会触发一次,即使被多个不同tasks通知。

- name: template configuration file
template:
src: template.j2
dest: /etc/foo.conf
notify:
- restart memcached
- restart apache

notify任务部分中列出的内容称为处理程序。

处理程序是任务的列表,与常规任务没有什么实质的不同,它们由全局唯一名称引用,并由通知程序通知。如果没有任何通知处理程序,它将不会运行。无论有多少个任务通知处理程序,在特定播放中完成所有任务后,它将仅运行一次。

这是处理程序部分的示例:

handlers:
- name: restart memcached
service:
name: memcache
dstate: restarted
- name: restart apache
service:
name: apache
state: restarted

将变量放在处理程序的任务参数中。您可以使用以下方式加载值include_vars:

tasks:
- name: Set host variables based on distribution
include_vars: "{{ ansible_facts.distribution }}.yml" handlers:
- name: restart web service
service:
name: "{{ web_service_name | default('httpd') }}"
state: restarted

从Ansible 2.2开始,处理程序还可以“侦听”通用主题

handlers:
- name: restart memcached
service:
name: memcached
state: restarted
listen: "restart web services" - name: restart apache
service:
name: apache
state: restarted
listen: "restart web services" tasks:
- name: restart everything
command: echo "this task will restart the web services"
notify: "restart web services"

执行playbook

运行并行度为10的剧本:

ansible-playbook playbook.yml -f 10

Ansible Pull的使用

ansible用于从git中拉取playbooks

通过ansible-pull命令与git、crontab共同使用,可以通过crontab定期拉去指定的git版本到本地,并以指定模式自动运行预先制定好的指令

 */20 * * * *  root /usr/local/bin/ansible-pull -o -C 2.1.0 -d /src/www/king-gw/  -i /etc/ansible/hosts - U git://git.kingifa.com/king-gw-ansiblepull >> /var/log/ansible-pull.log 2>&1

这里有一个写好的 clever playbook配置pull模式。

Linting playbooks

在执行之前,您可以使用ansible-lint对您的剧本进行详细检查。

$ ansible-lint verify-apache.yml
[403] Package installs should not use latest
verify-apache.yml:8
Task/Handler: ensure apache is at the latest version

其他剧本验证选项

ansible-playbook 与--syntax-check标志一起使用。这将通过解析器运行剧本文件,以确保其包含的文件,角色等没有语法问题。

ansible-playbook --syntax-check  playbook.yml

要在运行剧本之前查看哪些主机会受到该剧本的影响,可以执行以下操作:

ansible-playbook playbook.yml --list-hosts

Playbooks简介的更多相关文章

  1. Ansible1:简介与基本安装【转】

    Ansible是一个综合的强大的管理工具,他可以对多台主机安装操作系统,并为这些主机安装不同的应用程序,也可以通知指挥这些主机完成不同的任务.查看多台主机的各种信息的状态等,ansible都可以通过模 ...

  2. Ansible - 简介和应用自动化基础实践

    installAnsible简介和应用自动化基础实践 一.引入: 1.1  如官方定义,Ansible is The simplest way to automate apps and IT infr ...

  3. ansible学习系列1-ansible简介

    1.ansible简介 官方说明:Ansible is an IT automation tool. It can configure systems, deploy software, and or ...

  4. 【原创】运维基础之Ansible(1)简介、安装和使用

    官方:https://www.ansible.com/ 一 简介 Ansible is a radically simple IT automation engine that automates c ...

  5. Ansible 简介

    Ansible 是一个开源的基于 OpenSSH 的自动化配置管理工具.可以用它来配置系统.部署软件和编排更高级的 IT 任务,比如持续部署或零停机更新.Ansible 的主要目标是简单和易用,并且它 ...

  6. 001. Ansible简介

    一 简介 Ansible是一款极其简单的自动化运维工具, 基于Python开发, 集合了众多运维工具(puppet, cfengine, chef, func, fabric)的优点. 实现了批量系统 ...

  7. Ansible之入门简介

    一.ansible简介 ansible是一款由python语言编写的一款自动化运维工具,它集合了众多运维工具(puppet.cfengine.chef.func.fabric)优点,实现了批量系统配置 ...

  8. ansible-playbook简介

    1. ansible-playbook简介 • Playbooks 与 adhoc 相比,是一种完全不同的运用 ansible 的方式,是非常之强大的. • 简单来说,playbooks 是一种简单的 ...

  9. ansible 五 playbooks剧本使用

    一.Playbook 简介 Playbooks与Ad-Hoc相比,是一种完全不同的运用Ansible的方式,而且是非常之强大的:也是系统ansible命令的集合,其利用yaml语言编写,运行过程,an ...

随机推荐

  1. nohup 、&、 2>&1 命令分析

    nohup的意思是不间断的运行,&的意思是后台运行,2>&1的意思是标准输出和错误输出都重定向到同一个文件. 简单地说nohup运行时即使关掉控制台,它该运行还是运行. http ...

  2. BFS算法的优化 双向宽度优先搜索

    双向宽度优先搜索 (Bidirectional BFS) 算法适用于如下的场景: 无向图 所有边的长度都为 1 或者长度都一样 同时给出了起点和终点 以上 3 个条件都满足的时候,可以使用双向宽度优先 ...

  3. 【BZOJ 4004】 装备购买(高斯消元+贪心)

    装备购买 题目 脸哥最近在玩一款神奇的游戏,这个游戏里有 n 件装备,每件装备有 m 个属性,用向量zi(aj ,.....,am) 表示 (1 <= i <= n; 1 <= j ...

  4. mysql 事件计划

    一.开启mysql事件计划 首先在sql中查询计划事件的状态:SHOW VARIABLES LIKE 'event_scheduler'如果返回的是off表示当前是关闭状态,如果是on当前已经开启了计 ...

  5. angularJS开发环境搭建和启动

    本文目录:1.angularJS框架简介 2.angularJS环境搭建 3.启动一个项目 1.angularJS框架简介 AngularJS是一个开发动态Web应用的框架.它让你可以使用HTML作为 ...

  6. combineReducers(reducers)

    combineReducers(reducers) 随着应用变得越来越复杂,可以考虑将 reducer 函数 拆分成多个单独的函数,拆分后的每个函数负责独立管理 state 的一部分. combine ...

  7. Linux/Windows 配置config 使用ssh连接

    Linux 产看本地是否有ssh 公私钥 1 cd ~/.ssh 2 ls -a 有的话继续(没有 ssh-keygen 生成) 将公钥内容复制到要连接的服务器用户下 方法一 ssh-copy-id ...

  8. UFUN函数 UF_CURVE函数(UF_CURVE_create_line、UF_CURVE_create_arc、UF_CURVE_ask_arc_data、UF_CURVE_ask_line_data)

    UF_initialize(); //CSYS_ask_wcs tag_t wcs_id=NULL_TAG; //CSYS_ask_csys_info ]={0.0}; //CURVE_create_ ...

  9. 使用viper 进行golang 应用的配置管理

    viper 是一个强大的golang 配置管理包,支持多种配置格式内容的读取,同时支持读取key/value 存储的数据 而且不只是读取内容 ,同时也包含了,配置的写入操作. 以下是一个简单的demo ...

  10. 14-网页,网站,微信公众号基础入门(网页版MQTT,小试牛刀)

    https://www.cnblogs.com/yangfengwu/p/11192639.html 抱歉哈...最近由于做板子,,教程的进度落下了... 这些天总共做了还几块板子 首先对当前这个教程 ...