本篇主要是根据官方翻译而来,从而使简单的翻译,并无相关的实验步骤,之后文章会补充为实验步骤,此篇主要是相关理论的说明,能够称之为中文手册之一,具体内容以下:git
本文档主要阐述如何来写最好的playbook,在以下网址中能找到相关的例子,以下:github
https://github.com/ansible/ansible-examplesweb
在使用playbooks的最佳路径中,最好的方法是使用roles,这是最好的方法,在官方文档中,至少强调了三篇,从而在使用playbooks的时候,最好就是使用roles来进行组织playbook。centos
在使用roles进行组织的时候,是具备目录结构的,目录结构的使用也是将playbooks进行组织,在使用include的时候,主要是为了重用的目的,从而将复杂的playbook进行分割成小的,从而达到重用的目的,以下所示,表示为roles的目录组织结构。服务器
production # 生产环境服务器的列表(inventory file)架构 staging # 测试环境服务器列表(inventory file)app
group_vars/工具 group1 # 对特定的组分配变量布局 group2 # ""测试 host_vars/ hostname1 # 主机特定变量 hostname2 # ""
library/ # 客户端模块(可选) filter_plugins/ # 客户端过滤模块(可选)
site.yml # master playbook webservers.yml # webserver 的playbook dbservers.yml # dbserver 的playbook
roles/ common/ # 此层表示为一个 "role" tasks/ # main.yml # <-- 任务文件 handlers/ # main.yml # <-- handlers文件 templates/ # <-- 模板文件位置 ntp.conf.j2 # <------- 模板后缀符 .j2 files/ # bar.txt # <-- 拷贝文件资源 foo.sh # <-- script文件脚本资源 vars/ # main.yml # <-- 本role相关联的变量 defaults/ # main.yml # <-- 默认状况下优先级比较低的变量 meta/ # main.yml # <-- role的依赖
webtier/ # webtier的role,和comman的role结构相同 monitoring/ # "" fooapp/ # ""
|
在使用云的时候,能够不使用静态的inventory文件,可使用动态的inventory文件。
在测试环境和生产环境的管理中,主要用不一样的inventory文件来进行区分。
在进行使用playbook的时候,最好在测试环境中进行测试,而后再在生产环境中进行执行。
在管理静态的inventory文件的时候,若是来区分生产环境和测试环境,主要就是使用前缀名,以下所示
# file: production [atlanta-webservers] www-atl-1.example.com www-atl-2.example.com [boston-webservers] www-bos-1.example.com www-bos-2.example.com [atlanta-dbservers] db-atl-1.example.com db-atl-2.example.com [boston-dbservers] db-bos-1.example.com # webservers in all geos [webservers:children] atlanta-webservers boston-webservers # dbservers in all geos [dbservers:children] atlanta-dbservers boston-dbservers # everything in the atlanta geo [atlanta:children] atlanta-webservers atlanta-dbservers # everything in the boston geo [boston:children] boston-webservers boston-dbservers
|
在上图中,都使用相同的前缀名,从而来区分各个主机。
在进行管理不一样环境的主机的时候,推荐的作法是使用不一样的前缀名来进行区分主机环境,从而作到可读性比较强
组是比较容易管理的,可是并非全部组都是这样的,一样能够对组的变量进行设置,在下面例子中,atlanta有其本身的变量,从而定义以下:
--- # file: group_vars/atlanta ntp: ntp-atlanta.example.com backup: backup-atlanta.example.com
|
在进行设置组变量的时候,能够根据不一样组的属性从而来划分各个不一样的变量,当具备默认属性的时候,那么能够将变量值设置在一下目录中,group_vars/all,以下所示:
--- # file: group_vars/all ntp: ntp-boston.example.com backup: backup-boston.example.com
|
也能够在目录host_vars中定义具体的系统变量,可是应当尽可能避免此种状况的发生,以下图所示:
--- # file: host_vars/db-bos-1.example.com foo_agent_port: 86 bar_agent_port: 99
|
在site.yml中,可使用include一个playbook来表述一个总体的结构,注意在整个里面是很简短的,以下所示,playbooks是包含一系列的playbook:
--- # file: site.yml - include: webservers.yml - include: dbservers.yml
|
在文件webserver.yml中,也就是配置这个组所对应的role,以下所示:
--- # file: webservers.yml - hosts: webservers roles: - common - webtier
|
在进行运行的时候,咱们可使用site.yml来进行或者使用单独的webserver.yml来运行,以下就是来进行明确运行哪一个playbook:
ansible-playbook site.yml --limit webservers ansible-playbook webservers.yml
|
如下例子中演示如何使用一个role来进行工做,在这里能够作不少,以下所示:
--- # file: roles/common/tasks/main.yml - name: be sure ntp is installed yum: name=ntp state=installed tags: ntp - name: be sure ntp is configured template: src=ntp.conf.j2 dest=/etc/ntp.conf notify: - restart ntpd tags: ntp - name: be sure ntpd is running and enabled service: name=ntpd state=running enabled=yes tags: ntp |
下面的例子中,表示为一个handler,以下所示:
--- # file: roles/common/handlers/main.yml - name: restart ntpd service: name=ntpd state=restarted
|
在上面的roles组织中,如何开启这种布局结构
若是要从新配置组织架构,只要执行下面的命令便可:
ansible-playbook -i production site.yml
|
若是要从新配置NTP,执行下面命令便可:
ansible-playbook -i production site.yml --tags ntp
|
若是要从新配置webservers,以下:
ansible-playbook -i production webservers.yml
|
若是要从新配置boston的webservsers,以下:
ansible-playbook -i production webservers.yml --limit boston
|
若是要从新配置前十个和下十个,以下:
ansible-playbook -i production webservers.yml --limit boston[0-10] ansible-playbook -i production webservers.yml --limit boston[10-20]
|
若是要执行临时任务,以下:
ansible boston -i production -m ping ansible boston -i production -m command -a '/sbin/reboot'
|
比较有用的指令以下:
# confirm what task names would be run if I ran this command and said "just ntp tasks" ansible-playbook -i production webservers.yml --tags ntp --list-tasks # confirm what hostnames might be communicated with if I said "limit to boston" ansible-playbook -i production webservers.yml --limit boston --list-hosts |
在有的模块中,state是有默认值得,可是在playbook中最好是明确的标示state的状态是present仍是absent,而且在state还有其余值得时候,明确指定state的值有利于可读性。
若是是针对的是不一样操做系统的变量,最好的方法是使用group_by模块。这样会对动态的主机进行确认,虽然不在inventory文件中,以下:
--- # talk to all hosts just so we can learn about them - hosts: all tasks: - group_by: key=os_{{ ansible_distribution }} # now just on the CentOS hosts... - hosts: os_CentOS gather_facts: False tasks: - # tasks that only happen on CentOS go here
|
这样会造成将全部的系统造成一个动态组,基于操做系统的名称。
若是须要特殊的设置组,那么以下所示:
--- # file: group_vars/all asdf: 10 --- # file: group_vars/os_CentOS asdf: 42
|
上例中,表示出了centos的机器得到的值为10,centos的机器得到值为42
也能够设置如下的变量:
- hosts: all tasks: - include_vars: "os_{{ansible_distribution}}.yml" - debug: var=asdf
|
此种变量是基于操做系统的名称
在使用的时候,注意用空格来进行分割不一样的内容;
使用#来进行注释;
在书写playbook的时候,name最好是写上,从而代表相关的目的;
尽可能保持playbook的简洁性;
控制版本。
在进行变量设置的时候,最好放在相关的目录中,而且可使用grep等相关的工具来查找到变量位置。