ansible进阶(roles应用)

ansible 进阶

一、roles简介

一个项目从开始到结束,不是简单几十个playbook就可以完事了,当文件数很多,有上百个的话,仅通过简单的includes不停的引用,那最终的结果错综复杂。这个时候ansible roles就可以很好的发挥它的作用了。

roles,字面意思是角色的含义,可以理解为有相互关联功能的集合。我们把安装ntp、mem、nginx、db等等的功能角色放在一个大仓库里,然后用到哪个,从那里面去拿,拿一个,拿两个都可以。

roles:是个目录,角色集合

里面放的有:

    mysql/
    httpd/
    nginx/
    memcached/
每个角色是一个目录

每个角色的格式,一特定的层级目录结构进行组织,如下:

mysql/
    files/
    templates/
    tasks/
    handlers/
    vars/
    meta/
用到哪个目录,给出哪个目录

二、在playbook中调用角色的方式

- hosts: webservers
  remote_user: root
  roles:
  - mysql
  - memcached
  - nginx

三、以mysql/为例,分别介绍各个目录的意思

(1)files/:存放copy或script模块等调用的文件

(2)templates/:templates查找所需要模块文件的目录;

(3)tasks/:(必须要有)至少应该包含一个名为main.yml的文件,其他的文件需要在此文件中通过include进行包含;

(4)handlers/:至少应该包含一个名为main.yml的文件,其他的文件需要在此文件中通过include进行包含;

(5)vars/:定义的是变量,至少应该包含一个名为main.yml的文件,其他的文件需要在此文件中通过include进行包含;

(6)meta/:定义此当前角色的特殊设定及其他依赖关系,至少应该包含一个名为main.yml的文件,其他的文件需要在此文件中通过include进行包含;

(7)default/:为当前角色设定默认变量时使用目录中的main.yml文件

四、例子

(1)mkdir /etc/ansible/roles/nginx{files,tasks,templates,handlers,vars,default,meta} -pv

(2)tree /etc/ansible/roles/nginx

ansible进阶(roles应用)

(3)cd /etc/ansible/roles/nginx/

(4)vim tasks/main.yml

ansible进阶(roles应用)

(5)cp /root/working/files/nginx.conf.j2 templates/

(6)调用,去working目录下,建立一个ansible文件夹,cd到里面去,然后vim nginx.yml

ansible进阶(roles应用)

(7)运行结果

ansible进阶(roles应用)

五、其他配置添加

1、定义触发器

(1)cd /etc/ansible/roles/nginx 放在handlers目录下:vim handlers/main.yml

ansible进阶(roles应用)

(2)vim tasks/main.yml

ansible进阶(roles应用)

(3)ansible-playbook –check nginx.yml

ansible进阶(roles应用)

定义tags,直接在tasks/main.yml上加上tags: instconf就可以了

2、自定义变量的使用

(1)cd working/ ,vim myuser.yml

ansible进阶(roles应用)

(2)ansible-playbook myuser.yml

(3)再那两台机子上看一下:

ansible进阶(roles应用)

3、调用roles的第二种方法:传递变量给角色

mkdir -pv /etc/ansible/roles/memcached/tasks
cd /memcached
vim tasks/main.yml

- name: install package
  yum: name=memcached state=present
- name: start memcached
  service: name=memcached state=started enabled=true

调用:vim lnm.yml
- hosts: all
  remote_user:
  roles:
  - { role:nginx, when:ansible_distribution_major_version == '7' }
  - { role:memcached, when:ansible_hostname == 'memcached' }


ansible-playbook --check lnm.yml

大致先写到这,ansible是门庞大的课程,未完待续。

 

原创文章,作者:N24_yezi,如若转载,请注明出处:http://www.178linux.com/65914

(3)
N24_yeziN24_yezi
上一篇 2017-01-05
下一篇 2017-01-05

相关推荐

  • 特殊权限及facl

    Linux系统上的特殊权限          特殊权限:SUID,  SGID,  STICKY 安全上下文:         1、进程以某用户的身份运行,进程是发起此进程用户的代理,因此用户的身份和权限完成所有操作;     &…

    Linux干货 2016-11-07
  • rsync+inotify 实现数据实时同步

        Rsync (Rmote sync)是一款非常好的数据同步工具,能够通过对比同步双方的数据变动,实现增量同步,还可以通过LAN/WAN实现远程多台主机间文件的同步,还能结合crond任务计划来执行自动备份,又可以结合ssh实现远程数据备份的安全,种种特性使他看起来相当优秀。但如果需备份数据十分庞大时,它的不足之处就显现出来了,比如…

    Linux干货 2015-07-24
  • lvs-nat集群

    lvs-nat算法 nat模型样式 vs服务器:公网地址 172.18.250.253 私网地址 192.168.57.129 (DIP) 各私网服务器网关指向服务器DIP 各私网服务器做集群:web (telnet,ssh) 私网服务器使用httpd实现 rs私网服务器1 centos7 ip:192.168.57.132 rs私网服务器2 centos6…

    Linux干货 2017-05-15
  • Shell脚本编程基础

    1编程基础 程序:指令+数据 程序编程分格: 过程式:以指令为中心,数据服务于指令 对象式:以数据为中心,指令服务于数据 Shell程序:提供了编程能力,解释执行 程序的执行方式 计算机:运行二进制指令 编程语言: 低级:汇编 高级:编译:高级语言->编译器->目标代码 编译性语言编写的程序通常是需要通过编译器去转换成计算机可以识别的二进制文件,…

    2017-11-27
  • MairaDB之基于openssl的主从复制

    一、配置openssl   1、   在master server(node0)上根CA的搭建(及生成自签名证书) [root@node0 ~]# cd /etc/pki/CA/ [root@node0 CA]# (umask 077;openssl genrsa -out private/cakey.pem 2048) Gen…

    2016-11-19
  • 文本处理工具之grep

                    文本处理工具之grep 一、grep的简介 1、grep是一个文本过滤器的工具,它根据用户指定的模式(pattern)对目标文本进行匹配检查,并将匹配的行打印到标准输出或输出重定向。 2、模式:由文本字符或正则表达式组成 3、正则表达式分…

    2017-05-06

评论列表(1条)

  • luoweiro
    luoweiro 2017-02-23 07:43

    很详细的步骤,赞,加油。