参考: ansible中文权威指南

1. 动态Include

结合when等判断,在满足某个条件的时候加载。

- include: test.yml

when: ......

handler 中也可以使用include

 

2. ansible role 结构

roles目录结构一般如下,可以根据实际情况减少:

.
├── group_vars #定义主机组的变量,虽然可以写在playbook和hosts中,但是提倡分离.文件用组名命名.
│   ├── all.yml
│   ├── seawar_server.yml
│   ├── seawar.yml
│   └── test1.yml
├── hosts
├── host_vars #定义特定主机的变量,文件以主机命名,
│   └── ios-cn-.yml
├── main.yml #整个playbook的入口文件,组织多个role的任务执行。任务总调度文件。主要指定远程主机,执行用户,调用的roles等。
└── roles
├── base #roles的名字
│   ├── files #存放要传输文件的目录,不用在tasks/main.yml中写绝对路径就可以用
│   │   └── server.sh
│   ├── handlers
│   │   └── main.yml
│   ├── meta
│   ├── tasks
│   │   ├── fileup.yml #分离出来的任务,main.yml中include直接引用。
│   │   ├── main.yml #任务主函数,整个role的任务入口。
│   │   └── sql.yml #分离出来的任务,main.yml中include直接引用。
│   ├── templates # 模版文件,一般用于配置文件的变更
│   └── vars # 变量
│   └── main.yml #一般定义templates中要用到的变量
└── create_dir.sh

roles说明:

这个 playbook 为一个角色 ‘x’ 指定了如下的行为:

  • 如果 roles/x/tasks/main.yml 存在, 其中列出的 tasks 将被添加到 play 中
  • 如果 roles/x/handlers/main.yml 存在, 其中列出的 handlers 将被添加到 play 中
  • 如果 roles/x/vars/main.yml 存在, 其中列出的 variables 将被添加到 play 中
  • 如果 roles/x/meta/main.yml 存在, 其中列出的 “角色依赖” 将被添加到 roles 列表中 (1.3 and later)
  • 所有 copy tasks 可以引用 roles/x/files/ 中的文件,不需要指明文件的路径。
  • 所有 script tasks 可以引用 roles/x/files/ 中的脚本,不需要指明文件的路径。
  • 所有 template tasks 可以引用 roles/x/templates/ 中的文件,不需要指明文件的路径。
  • 所有 include tasks 可以引用 roles/x/tasks/ 中的文件,不需要指明文件的路径。

hosts定义如下:

[ios_cn]
iOS-CN--
iOS-CN--
iOS-CN--
iOS-CN--
iOS-CN--
iOS-CN-
iOS-CN- [ios_tw]
121.40.20.132 [an_360]
-
-
- [googleplay]
android-TW-- [jp_ios]
gNetop-iOS-JP--
gNetop-iOS-JP--
gNetop-iOS-JP--
gNetop-iOS-JP--
gNetop-iOS-JP--
gNetop-iOS-JP--
gNetop-iOS-JP--
gNetop-iOS-JP--
gNetop-iOS-JP- [jp_an]
gNetop-android-JP--
gNetop-android-JP--
gNetop-android-JP--
gNetop-android-JP- [na]
gNetop-NA-S1
gNetop-NA-S2
gNetop-NA-S3
gNetop-NA- [eu]
gNetop-EU-
gNetop-EU-
gNetop-EU- [sea]
gNetop-SEA-M1
gNetop-SEA-M2 [seawar_server:children]
ios_cn
ios_tw
jp_ios
na
eu
sea [seawar:children]
googleplay
an_360
jp_an [test]
172.10.30.239 [test1:children]
test

hosts

变量定义如下:  group_vars/all.yml  .应用于所有主机的变量

---

back_dir: "/mnt/back_2015/"

playbook 入口文件main.yml 定义如下:

---

- hosts:  jp_ios
remote_user: root #登录远程机器的用户, roles:
- u_776

roles/tasks中的文件如下:

---

- name: 上传数据库文件
copy:
src: "{{item.src}}"
dest: "{{item.dest}}"
owner: root
group: root
mode: 0755 with_items:
- { src: server.sql, dest: "{{back_dir}}" }
- { src: server.sh, dest: "{{back_dir}}" } - name: 执行数据库文件
shell: sh "{{back_dir}}"server.sh>server.txt chdir = "{{back_dir}}" #使用变量用引号。 sh命令去执行脚本。也可以在shell中直接执行命令。

更新数据库的任务

---

- name: 更新文件
copy:
src: "{{item.src}}"
dest: "{{item.dest}}"
with_items:
- { src: init, dest: "{{remote_dir}}" }
- { src: app, dest: "{{remote_dir}}" }

更新文件任务

---

- include: fileup.yml
#- include: sql.yml

tasks入口文件,include的使用

3. 跨平台roles,when判断实现

比如 redhat和ubuntu都要安装httpd.

首先定义两个roles httpd_ubuntu, httpd_redhat.  调用主文件如下:

---

- name: cross-platform install httpd

  hosts: cross-platfoem

  roles:   #通过facts自动收集的信息结合when判断来执行

    - {role: httpd_ubuntu, when: ansible_os_family="Ubuntu"}

    - {role: httpd_redhat, when: ansible_os_family="RedHat"}

4. jinja2 模版自定义

https://www.jianshu.com/p/ae74f5f39828

二、ansible的roles介绍:

ansible的roles用于层次性、结构化地组织palybook。roles能够根据层次型结构自动装载变量文件、tasks及handlers等。要使用roles只需要playbook中使用include指令即可。

rules的组成:

root@node1 playbook]# tree  roles/
roles/ \\ansible所有的信息都放到此目录下面对应的目录中
└── nginx \\角色名称
├── default \\为当前角色设定默认变量时使用此目录,应当包含一个main.yml文件;
├── files \\存放有copy或script等模块调用的文件
├── handlers \\此目录总应当包含一个main.yml文件,用于定义各角色用到的各handler
├── meta \\应当包含一个main.yml,用于定义角色的特殊设定及其依赖关系;1.3及以后版本支持
├── tasks \\至少包含一个名为main.yml的文件,定义了此角色的任务列表,可使用include指令
├── templates \\template模块会自动在此目录中寻找Jinja2模板文件
└── vars \\应当包含一个main.yml文件,用于定义此角色用到的变量
roles介绍完了,那么我们就利用ansible的roles来配置nginx 1、首先按照上面的要求创建要用到的目录 [root@node1 playbook]# mkdir -pv roles/nginx/{tasks,files,templates,handlers,vars,meta,default}
2、准备nginx配置文件 准备nginx.conf配置文件,使用模板文件配置
[root@node1 playbook]# cd roles/nginx/templates/
[root@node1 ~]# ansible all -m setup | grep ansible_processor_cores
"ansible_processor_cores": 1, \\获取ansible的要调用的相关函数
[root@node1 playbook]# cd roles/nginx/templates/ \\模板文件一定要放到此目录
[root@node1 templates]# vim nginx.conf
worker_processes {{ ansible_processor_cores }}; \\调用获取到的函数
准备nginx的default.conf文件
[root@node1 playbook]# ls -l roles/nginx/files/
-rw-r--r--. 1 root root 1290 Nov 12 2014 default.conf
3、准备nginx的rpm包 [root@node1 playbook]# ls -l roles/nginx/files/
-rw-r--r--. 1 root root 1290 Nov 12 2014 default.conf
-rw-r--r--. 1 root root 319456 Mar 29 20:44 nginx-1.4.7-1.el6.ngx.x86_64.rpm
4、在tasks目录中配置任务列表 [root@node1 playbook]# cd roles/nginx/tasks/
[root@node1 tasks]# vim main.yml
- name: copy nginx.rpm
copy: src=nginx-1.4.7-1.el6.ngx.x86_64.rpm dest=/tmp/nginx-1.4.7-1.el6.ngx.x86_64.rpm
- name: install nginx
shell: yum -y install /tmp/nginx-1.4.7-1.el6.ngx.x86_64.rpm
- name: provides nginx.conf
template: src=nginx.conf dest=/etc/nginx/nginx.conf
tags: nginxconf
notify:
- server restart
- name: provides default.conf
copy: src=default.conf dest=/etc/nginx/conf.d/default.conf
tags: nginxconf
- name: server start
service: name=nginx enabled=true state=started
5、在handlers目录中配置定义handler信息 [root@node1 playbook]# cd roles/nginx/handlers/
[root@node1 handlers]# vim main.yml
- name: server restart
service: name=nginx state=restarted
6、在roles同一级目录中创建site.yml文件 [root@node1 playbook]# cat site.yml
- hosts: nginx
remote_user: root
roles:
- nginx
7、应用配置: [root@node1 playbook]# ansible-playbook site.yml

playbook role应用的更多相关文章

  1. 014.Ansible Playbook Role 及调试

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

  2. [系统开发] 基于Ansible的产品上线系统

    前言: 应部门急需,开发了一套基于Ansible Playbook的产品上线系统.由于时间很紧,UI直接套用了之前开发的一套perl cgi模板,后续计划用 django 重新编写. 个人感觉该系统的 ...

  3. Ansible状态管理

     转载自:http://xdays.me/ansible状态管理.html 简介 就像所有服务器批量管理工具(puppet有DSL,salt有state)一样,ansible也有自己的状态管理组件 ...

  4. Nebula Graph 的 Ansible 实践

    本文首发于 Nebula Graph 公众号 NebulaGraphCommunity,Follow & 看大厂图数据库技术实践 背景 在 Nebula-Graph 的日常测试中,我们会经常在 ...

  5. Ansible-DevOps

    Ansible-DevOps Ansible 搭建 CentOS7 yum install epel-release yum search ansible yum install ansible -y ...

  6. ansible的playbook组件

    playbook的核心元素: tasks: 任务 variables: 变量 templates: 模板 handlers: 处理器 roles: 角色 组织格式:YAML(被称为另外一种标记语言) ...

  7. ansible playbook最佳实践

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

  8. Ansible10:Playbook的角色与包含【转】

    当单个playbook文件越来越大的时候,我们就需要重新来组织Playbooks了.我们可以将一个大的playbook拆成若干个小的playbook文件,然后通过include的方式,在主配置文件中将 ...

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

    html { font-family: sans-serif } body { margin: 0 } article,aside,details,figcaption,figure,footer,h ...

随机推荐

  1. Maven安装与配置及使用

    下载及安装 官方下载地址:直达官网下载页面 进入下载页面后,根据你电脑所装jdk版本选择对应版本的maven进行下载. 我们可以看到该页上边红框内写明了,maven3.3版以上支持的是JDK1.7+的 ...

  2. 解决ftp客户端连接验证报错Server sent passive reply with unroutable address. Using server address instead

    最近在linux服务器安装vsftp服务.经过一轮设置,终于可以连接上了,用winSCP连接,刷新目录就提示这个错误. 解决办法: vim /etc/vsftpd.conf  ,编辑配置文件,最后加上 ...

  3. PHP中get请求中参数的key不能是para

    &para会被转化成¶,然后就无法进行下去了. 仅作记录.

  4. @ModelAttribute设置request、response、session对象

    利用spring web提供的@ModelAttribute注解 放在类方法的参数前面表示引用Model中的数据 @ModelAttribute放在类方法上面则表示该Action类中的每个请求调用之前 ...

  5. cocos2dx-lua控制台报错集合

    1.invalid 'cobj' in function 'lua_cocos2dx_Node_getLocalZOrder' 这个报错是lua的变量还在,但是他底层对应的C++对象已被销毁.

  6. 12c rac On redhat 7

    1  准备工作 1.1   关于GRID的一些变化 1.1.1  简化的基于映像的Oracle Grid Infrastructure安装 从Oracle Grid Infrastructure 12 ...

  7. react.css

    /* KISSY CSS Reset 理念:清除和重置是紧密不可分的 特色:1.适应中文 2.基于最新主流浏览器 维护:玉伯(lifesinger@gmail.com), 正淳(ragecarrier ...

  8. JS实现的ajax和同源策略

    一.回顾jQuery实现的ajax 首先说一下ajax的优缺点 优点: AJAX使用Javascript技术向服务器发送异步请求: AJAX无须刷新整个页面: 因为服务器响应内容不再是整个页面,而是页 ...

  9. Eclipse中部署Android开发环境插件安装问题方案

    1.添加第一个插件ADT之后出现eclipse原有的SDK管理问题.需要重新安装SDK 2.一种方式按照系统提示直接联网自动搜索安装,另一种就是下载好之后import. 1.用接口声明的变量称为接口变 ...

  10. 【转】运维DBA的4大纪律9项注意

    朋友们调侃说,运维是个把脑袋别在裤腰带上的活,更有人说,运维是个把脑袋别在他人裤腰带上的活,苦劳没人认,有锅就有得背! 测试的同学说,“吃瓜群众很难感知运维背后的付出,倒是出了事情更能体现我们的专业性 ...