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

相关推荐

  • 第十一周作业

    1、详细描述一次加密通讯的过程,结合图示最佳。 发送者:     1)使用单向加密算法提取要发送文件的特征码;     2)使用自己的私钥加密特征码并附加在数据后面;     3)生成用于对称加密的临时密码;     4)用此临时密钥加密数据和已经使用私钥加密后的特征码; &nb…

    2017-03-20
  • YUM 的使用和YUM源的配置

    简介     yum(Yellow dog Updater Modified)是CentOS中属于RPM前端软件包管理器,能从指定的服务器中下载RPM包,并自动分析和处理RPM包之间的依赖关系,最后将依次所依赖的软件包都安装了,而无需繁琐的一个一个安装。 一 yum repository:yum仓库 yum仓库的组成部…

    Linux干货 2016-02-14
  • N25第8周作业

    1、写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态;     在线的主机使用绿色显示;      不在线的主使用红色显示; #!/bin/bash ipnet=172.20.51. trap ‘trap_action’ INT trap…

    Linux干货 2017-02-22
  • RAID and LVM

    RAID          Redundant Arrays of  inexpensive(Independent)Disks,RAID:容错式廉价磁盘阵列,容错式独立磁盘阵列,简称RAID,由加利福尼亚大学伯克利分校(University of California-Berkeley)在1988…

    Linux干货 2016-09-02
  • Linux iptables配置应用

                    Linux iptables配置应用 概述:    Linux的防火墙体系主要工作在网络层,只对tcp/ip数据包实施过滤和限制,属于典型的包过滤防火墙(或称为网络层防火墙)。Linux的防火墙体系基于内核编码实现,因…

    系统运维 2016-11-18
  • rsyslog将日志记录于MySQL中,并用loganalyzer进行分析日志

    1、首先来安装lamp环境的支持,与其相关的软件包      # yum -y install rsyslog-mysql mariadb-server php php-mysql php-gd httpd       说明:rsyslog-mysql在数据库中生成一个库文件,但这个文件需…

    Linux干货 2016-10-23

评论列表(1条)

  • luoweiro
    luoweiro 2017-02-23 07:43

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