先看一个yml文件示例

---
- hosts: webservers #主机组
vars: ##变量设置
http_port: 80
max_clients: 200
remote_user: root
tasks: ###主要任务
- name: ensure apache is at the latest version
yum: pkg=httpd state=latest
- name: write the apache config file
template: src=/srv/httpd.j2 dest=/etc/httpd.conf
notify: ##条件触发,根据handlers的名称执行相应的handlers
- restart apache ##重启apache服务(找 handlers,名称为restart apache的handlers)
- name: ensure apache is running
service: name=httpd state=started
handlers: ##在发生改变时执行的操作
- name: restart apache
service: name=httpd state=restarted

notify 下列出的即是 handlers. 

  Handlers 也是一些 task 的列表,通过名字来引用,它们和一般的 task 并没有什么区别.Handlers 是由通知者进行 notify, 如果没有被 notify,handlers 不会执行.不管有多少个通知者进行了 notify,等到 play 中的所有 task 执行完成之后,handlers 也只会被执行一次.

常用参数命令

-u REMOTE_USER, --user=REMOTE_USER     # ssh 连接的用户名 

-k, --ask-pass               #ssh登录认证密码 

-s, --sudo       #sudo 到root用户,相当于Linux系统下的sudo命令 

-U SUDO_USER, --sudo-user=SUDO_USER     #sudo 到对应的用户 

-K, --ask-sudo-pass           #用户的密码(—sudo时使用) 

-T TIMEOUT, --timeout=TIMEOUT       # ssh 连接超时,默认  秒 

-C, --check       # 指定该参数后,执行 playbook 文件不会真正去执行,而是模拟执行一遍,然后输出本次执行会对远程主机造成的修改 

-e EXTRA_VARS, --extra-vars=EXTRA_VARS       # 设置额外的变量如:key=value 形式 或者 YAML or JSON,以空格分隔变量,或用多个-e 

-f FORKS, --forks=FORKS       # 进程并发处理,默认  

-i INVENTORY, --inventory-file=INVENTORY     # 指定 hosts 文件路径,默认 default=/etc/ansible/hosts 

-l SUBSET, --limit=SUBSET       # 指定一个 pattern,对- hosts:匹配到的主机再过滤一次 

--list-hosts               # 只打印有哪些主机会执行这个 playbook 文件,不是实际执行该 playbook 

--list-tasks           # 列出该 playbook 中会被执行的 task 

--private-key=PRIVATE_KEY_FILE     # 私钥路径 

--step                 # 同一时间只执行一个 task,每个 task 执行前都会提示确认一遍 

--syntax-check           # 只检测 playbook 文件语法是否有问题,不会执行该 playbook 

-t TAGS, --tags=TAGS         #当 play 和 task 的 tag 为该参数指定的值时才执行,多个 tag 以逗号分隔 

--skip-tags=SKIP_TAGS         # 当 play 和 task 的 tag 不匹配该参数指定的值时,才执行 

-v, --verbose             #输出更详细的执行过程信息,-vvv可得到所有执行过程信息。

playbook Roles(角色)

语言格式:yml

  • 大小写敏感
  • 使用缩进表示层级关系(只能用空格,不能用tab)
  • yml文件以‘---’开始
  • 支持的数据结构:字典,列表、数字、布尔、字符串
  • 列表形式

    - A

    - B

    - C

YAML格式在线校验 :http://www.bejson.com/validators/yaml_editor/

项目结构:

project_name
  site.yml                #整个任务的yml入口(名称自定义)
group_vars/all               # 存放所有变量信息
  webservers.yml
  fooservers.yml
  roles/
  common/                #role-name
  files/ ##存放配置文件,不用指绝对路径
  templates/ ##存放模板文件,不用指绝对路径
  tasks/ ##默认的主要任务入口
  handlers/ #在notify时执行的操作
  vars/ ##存放变量文件
  defaults/ #可忽略
  meta/ #角色(roles)依赖
  webservers/              #role-name
  files/
  templates/
  tasks/
  handlers/
  vars/
  defaults/
  meta/

根据上面的项目结构:

参数化的 roles,这种方式通过添加变量来实现 

为 roles 设置触发条件

定义一些 tasks,让它们在 roles 之前以及之后执行

Files和templates

  files和templates均用于ansible文件处理,两者的主要区别是:Files目录下的文件无需写绝对路径即可将文件传输到远程主机,templates目录下文件以Jinja2渲染,支持传送到主机文件的变量替换

template变量示例可看 https://www.cnblogs.com/FRESHMANS/p/8204721.html,template文件内的变量可在vars目录里直接定义

includes

使用场景:有时候发现大量的playbook内容需要重复编写,各task之间需要相互调用才能完成各自功能

官网示例

include 传递变量

动态include,在include的基础上加上when 条件判断

playbook include playbook

---
- hosts: all
remote_user: root
tasks: [...] - include: web.yml - include: db.yml

ansible-playbook && Roles && include的更多相关文章

  1. Ansible Playbook Roles and Include Statements

    介绍 虽然可以在一个非常大的文件中编写一个playbook(您可能会以这种方式开始学习playbook),但最终您将需要重新使用文件并开始组织事情. 在基本级别,饱含任务的文件允许您将配置策略分解成较 ...

  2. Ansible playbook roles

    1  概述 角色(roles):如果我们使用playbook写成一个文件,这个文件会很大,但是不方便组织,我们可以分组,把playbook根据功能,如handler,tasks等分门别类的放在在各自的 ...

  3. ansible playbook最佳实践

    本篇主要是根据官方翻译而来,从而使简单的翻译,并没有相关的实验步骤,以后文章会补充为实验步骤,此篇主要是相关理论的说明,可以称之为中文手册之一,具体内容如下: Ansible playbooks最佳实 ...

  4. ansible playbook模式及语法

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

  5. 014.Ansible Playbook Role 及调试

    一 role 简介 在ansible中,role是将playbook分割为多个文件的主要机制,大大简化了复杂的playbook的编写,同时已与复用 role各个目录的作用及可用文件 files:存放由 ...

  6. Ansible之roles模块--lnmp分布式部署

    Ansible之roles模块--lnmp分布式部署 目录 Ansible之roles模块--lnmp分布式部署 1. role模块的作用 2. roles的目录结构 3. roles内个目录含义解释 ...

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

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

  8. Ansible playbook基础组件介绍

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

  9. ansible入门四(Ansible playbook基础组件介绍)

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

随机推荐

  1. 关于QQ的NABCD模型

    组名:思甜雅 关于QQ的NABCD模型 N--Need 随着电脑的普及,人们需要在网络上进行交流,现有的交流工具不够完善,不能够全部满足人们对于交流沟通中的需要. 初步了解人们的需求,人们需要一款可以 ...

  2. Practice4 阅读《构建之法》6-7章

    关于第五章后面的阅读已经在Practice3中有所感悟,下面是6-7章的读书笔记. 第6章 敏捷流程这一章讲了“敏捷流程”这一概念,关于这一名词我是很陌生的,在阅读之后有了一定的理解.敏捷流程是提供了 ...

  3. 第二次sprint

    一.这次冲刺就是实施阶段了,主要对程序进行一次骨架的构建,基本上已经完成了界面的设计,但是在算法上还有很大漏洞,整个程序还是属于不成熟阶段. 二.这是我们的界面 三.已经有的功能:随机生成题目并算出答 ...

  4. HDOJ2004_成绩转换

    水题:用数组标识各个阶段分数的等级即可. HDOJ2004_成绩转换 #include<stdio.h> #include<stdlib.h> #include<math ...

  5. Balanced Ternary String CodeForces - 1102D (贪心+思维)

    You are given a string ss consisting of exactly nn characters, and each character is either '0', '1' ...

  6. chrome启用flash不询问

    69版本之后 打开 chrome://flags/#enable-ephemeral-flash-permission 把它从Default改为Disabled 重新打开Chrome,进入 chrom ...

  7. Mark 韦氏拼音 邮政式拼音 和汉语拼音

    一直感觉很多大学名字不像是汉语拼音也不像是英文,百度了下原来是三种不同的拼音方式: 转载百度百科: 邮政式拼音和威妥玛拼音法并未完全消失.北京大学(Peking University).清华大学(Ts ...

  8. php 7.1 openssl_decrypt() 代替 mcrypt_module_open() 方法

    公司开发微信第三方平台,之前用着一直是没有问题的.后来服务器到期进行项目搬迁就怎么也接收不到微信每10分钟的ticketle. 经过调试发现php版本由原来的7.0升到了7.1(该死....为什么没人 ...

  9. socketserver及相关的类 (处理socket服务端)+ event事件的使用

    编写简单的套接字服务器并不难,然而,如果要创建的并非简单服务器,还要求助于服务器模块. 模块SocketServer是标准库提供的服务器框架的基石,这个框架包括好多服务器,他们基本服务器的基础上添加了 ...

  10. linux 单引号,双引号,反引号的小总结。

    还是老惯例说说事情的起因,由于最开始对linux下面的各种引号并不是特别敏感,导致有一天我在添加数据库字段的时候出现的错误,当时出现错误的原因是我在最外层使用了单引号进行包裹,然后一句话里面需要转意的 ...