Ansible-PlayBook的roles和Include
Include:在大型复杂架构中,第一个要面对的问题就是不断增长的playbook文件大小,一个很大的playbook很难去理解和维护,结局方法就是使用include,将你的plays分解成多个不同的段,然后在其他的plays中去包含他们。不同的段根据不同目的分类。全部包含在主plays中。
共有四种类型的包含:
1.变量包含:允许你将变量存在外部YAML文件
举例:
1
2
3
vars_files:
- vars.yml
- vars1.yml
2.playbook包含:一个大型项目中可以包含多个plays
3.任务包含:将任务放到普通文件中,当需要的时候包含他们
举例:
1
2
3
4
5
tasks: vars_files:
- vars.yml
- vars1.yml
- include:takes/foo.yml
4.Handler包含:允许你将所有的handlers处理程序放到一个地方
举例:
1
2
handlers:
- include:
Roles:
如果你的playbook增长到包含也无法解决问题,或者你已经拥有一个数量巨大的模板,你或许就该使用roles了。它允许你根据定义的格式对文件进行分组,从本质上来讲,它是一个具有一些自动化功能的包含,roles可以帮你很好的组织你的资料库。
roles允许你将变量、文件、任务、模板、handles放到一个文件夹中,然后包含它们。在建立好一个有效的依赖关系后,你还可以在一个roles中包含另外一个roles。和包含一样,你可以传递变量给roles。利用这些特性,你可以创建一个自包含的roles并很容易跟其他人分享它
·比如要用template模块,把一个文件拷贝到远程主机上,需要把这个文件放到template目录下
举例:
1
2
- name:copy httpd conf
template: src httpd.confdest=/etc/http/httpd.conf owner=root group=root mode=0755
·比如要用copy模块,把一个文件拷贝到远程主机上,需要把这个文件放到files目录下
举例:
1
2
- name
copy: src index.jsp dest=/data/www owner=root group=root mode=0755
---------------------------------------------------------------------------------
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
├── ansible.cfg
├── group_vars
│ └── all
├── init.yml #定义所有主机执行roles下的create-sudo-user
├── inventory
│ ├── test.ini
│ └── test_public.ini
├── main.yml
├── README.md
├── roles
│ ├── bamboo
│ │ ├── files
│ │ │ └── dataman-bamboo-0.9.0.tar.gz
│ │ ├── tasks
│ │ │ └── main.yml
│ │ └── templates
│ │ ├── install.sh.j2
│ │ └── supervisor-bamboo.j2
│ ├── chronos
│ │ ├── tasks
│ │ │ └── main.yml
│ │ └── templates
│ │ └── supervisor-chronos.j2
│ ├── common
│ │ ├── tasks
│ │ │ └── main.yml
│ │ └── templates
│ │ ├── dataman.repo.j2
│ │ └── docker.j2
│ ├── copy-authorized-key
│ │ ├── files
│ │ │ └── id_rsa_ansible.pub
│ │ └── tasks
│ │ └── main.yml
│ ├── create-sudo-user
│ │ ├── files
│ │ │ └── mesos
│ │ └── tasks
│ │ └── main.yml
│ ├── marathon
│ │ ├── tasks
│ │ │ └── main.yml
│ │ └── templates
│ │ ├── hostname.j2
│ │ ├── http_port.j2
│ │ ├── master.j2
│ │ └── zk.j2
│ ├── mesos-master
│ │ ├── tasks
│ │ │ └── main.yml
│ │ └── templates
│ │ ├── cluster.j2
│ │ ├── hostname.j2
│ │ ├── ip.j2
│ │ ├── quorum.j2
│ │ └── zk.j2
│ ├── mesos-slave
│ │ ├── tasks
│ │ │ └── main.yml
│ │ └── templates
│ │ ├── hostname.j2
│ │ ├── ip.j2
│ │ └── zk.j2
│ └── zookeeper
│ ├── tasks
│ │ └── main.yml
│ └── templates
│ ├── cloudera-cdh5.repo.j2
│ ├── myid.j2
│ └── zoo.cfg.j2
├── test.json
└── Vagrantfile
页:
[1]