123213 发表于 2015-11-23 09:28:43

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]
查看完整版本: Ansible-PlayBook的roles和Include