1、简单格式要求

[root@ansibleserver ansible]# cat nagios.yml

---

- hosts: nagiosserver

tasks:

- name: ensure nagios service stop

service: name=nagios state=stopped

- name: ensure nagios service start

service: name=nagios state=started

a、整体格式用---开始

b、在冒号之后,必须存在一个空格

c、name和service必须对齐

d、hosts和tasks必须对齐

e、在书写key和value的时候,不能存在空格

f、 在roles中的main.yml不能使用tasks关键词,主要是因为在目录结构中已经包含了此关键词,main.yml是存在于tasks目录中。

如果违反以上规定,那么就会出错,出错内容如下:

ERROR: Syntax Error while loading YAML script, nagios.yml

Note: The error may actually appear before this position: line 3, column 1

- hosts: nagiosserver

tasks:

^

2、运行playbook

对上面格式中的nagios.yml进行运行,运行命令如下:

[root@ansibleserver ansible]# ansible-playbook nagios.yml

在上面的playbook中,存在两个任务,一个是停止nagios服务,一个是启动nagios服务,运行结果如下所示:

PLAY [nagiosserver] ***********************************************************

GATHERING FACTS ***************************************************************

ok: [192.168.1.20]

TASK: [ensure nagios service stop] ********************************************

changed: [192.168.1.20]

TASK: [ensure nagios service start] *******************************************

changed: [192.168.1.20]

PLAY RECAP ********************************************************************

192.168.1.20               : ok=3    changed=2    unreachable=0    failed=0

可以看到,定义为name的地方会在输出中进行显示,然后显示运行结果,也就是changed,从而在第一个任务中,表示关闭服务成功,第二个任务中,表示为启动服务成功,最后会显示结果,也就是OK为3,表示连接成功,关闭服务成功,启动服务成功,chenged为2,表示为进行了两次修改。

3、最佳实践

创建roles的组织目录结构可以用如下语句(一次性创建目录组织架构,修改common表示相关的roles):

mkdir -p roles/common/{tasks,handlers,templates,files,vars,defaults,meta}

总体目录结构如下所示:

[root@ansibleserver kel]# ls -l

total 28

drwxr-xr-x 2 root root 4096 Jan 27 06:23 group_vars

-rw-r--r-- 1 root root  108 Jan 28 11:35 hosts

drwxr-xr-x 2 root root 4096 Jan 28 11:34 host_vars

-rw-r--r-- 1 root root   97 Jan 27 06:21 production.yml

drwxr-xr-x 4 root root 4096 Jan 27 06:17 roles

-rw-r--r-- 1 root root   53 Jan 28 11:27 site.yml

-rw-r--r-- 1 root root   77 Jan 27 06:21 staging.yml

在定级目录中,roles和site.yml和staging.yml和production.yml,group_vars和host_vars在同一级目录中,在变量的优先级中,host_vars的变量优先级比group_vars的优先级高,使用的变量的时候,如果名字相同,那么host_vars中变量的值会覆盖group_vars中变量的值,在roles中设置变量的时候,roles中变量的优先级又比host_vars高

在这里site.yml包含staging和production的playbook,从而在这里使用的是include,在staging和production中使用的是roles,从而需要注意的是roles里的目录结构,roles的目录结构如下所示:

[root@ansibleserver kel]# cd roles

[root@ansibleserver roles]# ls -l

total 8

drwxr-xr-x 3 root root 4096 Jan 27 06:18 adduser

drwxr-xr-x 4 root root 4096 Jan 24 14:13 changepassword

[root@ansibleserver roles]# cd changepassword/

[root@ansibleserver changepassword]# ls -l

total 8

drwxr-xr-x 2 root root 4096 Jan 27 06:22 tasks

drwxr-xr-x 2 root root 4096 Jan 28 11:43 vars

[root@ansibleserver changepassword]# cd tasks/

[root@ansibleserver tasks]# ls -l

total 4

-rw-r--r-- 1 root root 140 Jan 27 06:22 main.yml

在roles中,包含的文件夹也就是staging中包含的roles,也就是一个文件夹,表示一个roles,在上面的例子中分为adduser和changepassword两个roles,在子目录中,包含tasks和vars,表示所进行的任务和变量,还有其他的文件夹没有进行创建,从而在最后是一个main.yml

分别的内容如下:

[root@ansibleserver tasks]# cat main.yml

---

#- hosts: ansibleservers

#  use the variables kel to change the user root's passwrod

- name: change the user root password

shell: 'echo "{{kel}}"|passwd --stdin root > /dev/null 2>&1'

此内容主要是用kel变量的值作为root用户的密码

[root@ansibleserver kel]# cat site.yml

---

- include: staging.yml

- include: production.yml

此中的内容,主要就是使用include语句来包含另外两个playbook

[root@ansibleserver kel]# cat staging.yml

---

- hosts: ansibleserver1

roles:

- changepassword

#      - adduser

此种的内容,主要是用来表示修改密码,使用的是roles,在使用roles的时候,注意目录结构,使用roles的方式也是推荐的一种方式。

执行的时候如下:

[root@ansibleserver kel]# ansible-playbook -i hosts site.yml

SSH password:

PLAY [ansibleserver1] *********************************************************

GATHERING FACTS ***************************************************************

ok: [192.168.1.163]

TASK: [changepassword | change the user root password] ************************

changed: [192.168.1.163]

PLAY [ansibleserver2] *********************************************************

GATHERING FACTS ***************************************************************

ok: [192.168.1.164]

TASK: [changepassword | change the user root password] ************************

changed: [192.168.1.164]

PLAY RECAP ********************************************************************

192.168.1.163              : ok=2    changed=1    unreachable=0    failed=0

192.168.1.164              : ok=2    changed=1    unreachable=0    failed=0

发现执行成功,再最佳实践里推荐的就是用roles来执行相关的任务,然后将生产环境和测试环境进行分开。

更新一下github的地址,在里面写了相关模块的例子,从而可以进行查看,以后会根据相关的东西,从而写出相关的playbook

ansibleplaybook的使用的更多相关文章

  1. ansible-playbook

    一.ansible-playbook介绍: playbook是由一个或多个"play"组成的列表.play的主要功能在于将事先归为一组的主机装扮成事先通过ansible中的task ...

  2. ansible-playbook相关

    获取目标主机的信息 ansible all -m setup -a "filter=ansible_os_family" 不执行仅测试 ```sh 安装一个zabbix-agent ...

  3. ansible-playbook(nginx例)

    一.创建目录结构 cd /etc/ansible/roles/ mkdir nginx/{files,templates,vars,handlers,meta,default,tasks} -pv 二 ...

  4. ansible-playbook用法

    一.playbook用法 1.playbook的执行文件为YAML语言编写,所以文件名为xxx.yml.YAML语法可以参考https://docs.ansible.com/ansible/lates ...

  5. linux --- Ansible-playbook篇

    Ansible-playbook简介 什么是playbook? 简单点说,playbook就是ansible用于配置,部署和管控节点机器的剧本,将一系列命令的集合归一使用,类似于shell脚本,不过更 ...

  6. ansible-playbook 进行批量安装tomcat8

    ansible-playbook 进行安装tomcat操作 说明: get_url  中下载的内容直接到目的主机 安装的时候需要指定copy: no,说明需直接从目标主机进行安装包 [root@ans ...

  7. zabbix 应用监控作业笔记 ansible-playbook

    目录 目录结构 zabbix-web.yaml zabbix-backup.yaml zabbix-nfs.yaml zabbix-mysql.yaml zabbix-server.yaml zabb ...

  8. ansible-playbook 实战案例 全网备份 实时备份

    目录 ansible-playbook 基础介绍 1.YAML三板斧 2. ansible playbook 安装apache 示例 案例 全网备份 实时备份 环境规划 目录规划 base.yaml ...

  9. 2.ansible-playbook基本参数

    ansible-playbook的参数--force-handlers run handlers even if a task fails 强制执行handler--list-tags list al ...

随机推荐

  1. AngularJs-ui modal 封装 dialog

    常常在操作中和用户进行交互,及时反馈操作结果:用到alert 和confrim 功能 找到一个基于anguarjs-ui的modal,方便我们使用 angular-dialog-service 注意要 ...

  2. OpenMp之false sharing

    关于false sharing的文章,网上一大堆了,不过觉得都不太系统,那么下面着重系统说明一下. 先看看外国佬下的定义: In symmetric multiprocessor (SMP) syst ...

  3. asp天猫自主发码的请求

    这几天在做天猫自主发码.实现了通知和核销部门.其他的部分待后续实现. 值得注意的是consume回调中,要加入sign_method=md5

  4. debian系统安装Thinkpad T410s的无线网卡驱动:centrino Advanced-N 6200 2x2 AGN

    前几天搞到手一台小黑:T410s.自带系统是win7.由于想学习debian,所以就搞成了双系统,安装了一套debian 6.0. 可是让我困惑的是在debian下,无法使用T410s的网卡,因为默认 ...

  5. [POJ1631]Bridging signals (DP,二分优化)

    题目链接:http://poj.org/problem?id=1631 就是求一个LIS,但是范围太大(n≤40000),无法用常规O(n²)的朴素DP算法,这时需要优化. 新加一个数组s[]来维护长 ...

  6. iOS 8 AutoLayOut入门

    http://blog.csdn.net/asdfg13697116596/article/details/42562565 iOS 8 AutoLayOut入门自从iOS6带来Auto Layout ...

  7. 使用MySQL Proxy解决MySQL主从同步延迟

    MySQL的主从同步机制非常方便的解决了高并发读的应用需求,给Web方面开发带来了极大的便利.但这种方式有个比较大的缺陷在于MySQL的同步机制 是依赖Slave主动向Master发请求来获取数据的, ...

  8. 基于Html5的爱情主题网站–表白神器(第二版)

    第二版在第一版的基础上增加了一个动态3D的白云效果背景,鼠标悬浮在页面上云朵会向屏幕Z轴方向运动,在第一人称视角看来向着云朵方向前进的,由此形成一个伪3D效果.有点绕,直接看demo就能理解了.3D白 ...

  9. phonegap 百度云推

    1 创建新工程 -----获取api key 和secret key 2,推送设置 3,新建安卓项目,并把应用包名 和 推送中设置的包名设置一致 4,下载百度云客户端sdk 5,解压,并添加libs文 ...

  10. jquery事件学习笔记(转载)

    一.页面载入1.ready(fn)当DOM载入就绪可以查询及操纵时绑定一个要执行的函数.这是事件模块中最重要的一个函数,因为它可以极大地提高web应用程序的响应速度. 简单地说,这个方法纯粹是对向wi ...