码迷,mamicode.com
首页 > 其他好文 > 详细

Ansible-PlayBook的roles和Include

时间:2015-11-22 06:46:52      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:ansible

Include:

在大型复杂架构中,第一个要面对的问题就是不断增长的playbook文件大小,一个很大的playbook很难去理解和维护,结局方法就是使用include,将你的plays分解成多个不同的段,然后在其他的plays中去包含他们。不同的段根据不同目的分类。全部包含在主plays中。

共有四种类型的包含:

1.变量包含:允许你将变量存在外部YAML文件

举例:

   vars_files:
       - vars.yml
       - vars1.yml

2.playbook包含:一个大型项目中可以包含多个plays

3.任务包含:将任务放到普通文件中,当需要的时候包含他们

举例:

tasks: vars_files:
       - vars.yml
       - vars1.yml  
 
       - include:takes/foo.yml

4.Handler包含:允许你将所有的handlers处理程序放到一个地方

举例:

handlers:
    - include:

Roles:

     如果你的playbook增长到包含也无法解决问题,或者你已经拥有一个数量巨大的模板,你或许就该使用roles了。它允许你根据定义的格式对文件进行分组,从本质上来讲,它是一个具有一些自动化功能的包含,roles可以帮你很好的组织你的资料库。

      roles允许你将变量、文件、任务、模板、handles放到一个文件夹中,然后包含它们。在建立好一个有效的依赖关系后,你还可以在一个roles中包含另外一个roles。和包含一样,你可以传递变量给roles。利用这些特性,你可以创建一个自包含的roles并很容易跟其他人分享它

·比如要用template模块,把一个文件拷贝到远程主机上,需要把这个文件放到template目录下

举例:

- name:  copy httpd conf
  template: src httpd.confdest=/etc/http/httpd.conf owner=root group=root mode=0755

·比如要用copy模块,把一个文件拷贝到远程主机上,需要把这个文件放到files目录下

举例:

 - name
   copy: src index.jsp dest=/data/www owner=root group=root mode=0755

---------------------------------------------------------------------------------

├── 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


本文出自 “翟军铭的linux博客” 博客,请务必保留此出处http://zhaijunming5.blog.51cto.com/10668883/1715634

Ansible-PlayBook的roles和Include

标签:ansible

原文地址:http://zhaijunming5.blog.51cto.com/10668883/1715634

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!