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

相关推荐

  • 笔记–8.8 shell脚本编程

    shell编程注意事项  1,指令的执行是从上而下,从左而右的分析与执行  2,指令的下达时:指令,选项与参数之间的多个空白都会被忽略掉  3,空白行会被忽略掉,并且tab键所推开的空白同样视为空格键  4. 如果一行的内容太多,则可以使用『 \[Enter] 』来延伸至下一行  5,『 # 』可做为批注,任…

    Linux干货 2016-08-12
  • N26-肉肉-第二周作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 常用文件管理命令有cp,mv,rm  cp :copy        -i:交互式复制,覆盖之前提醒用户确认;         &n…

    Linux干货 2017-01-03
  • 命令行历史和调用命令参数

    history显示当前终端的历史记录 !! 重复执行上一条命令 !-n 重复执行倒数第n条命令 !n 重复执行第n条命令 ctrl+p 等于向上方向键,翻出上一条命令。 ctrl+n 等于向下方向键,翻出下一条命令。 ctrl+j 等于enter 执行当前命令 !:0 执行前一条命令(去除参数) !string 重复前一个以“string”开头的命令(只限于…

    2017-07-14
  • CA证书服务搭建与申请

    服务端根CA创建证书 进入固定目录,创建所需要的文件 cd /etc/pki/CA/ touch /etc/pki/CA/index.txt 生成证书索引数据库文件 echo 01 > /etc/pki/CA/serial 指定第一个颁发证书的序列号 生成秘钥 (umask 066;openssl genrsa -out /etc/pki/CA/pri…

    2017-09-11
  • Linux常用基础命令

    pwd显示工作目录 [root@localhost ~]# pwd/root cd 切换回家目录,注意:bash中,~表示家目录: [root@localhost ~]# cd[root@localhost ~]# cd ~USERNAME:切换至指定用户的家目录;cd ~切换回自己的家目录; cd -:在上一次所在目录与当前目录之间来回切换; […

    Linux干货 2017-06-26
  • Vim

    vim编辑器         vim,可谓文本编辑界的大哥,功能强大无比,是进阶版的vi, vim 不但可以用不同颜色显示文字内容,还能够进行诸如 shell script, C program等程序编辑功能。 vim是一种模式化的编辑器  (vim自带教程,命令行中输…

    Linux干货 2016-08-09

评论列表(1条)

  • luoweiro
    luoweiro 2017-02-23 07:43

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