设为首页 收藏本站
查看: 1006|回复: 0

[经验分享] Ansible自动化部署之ROLES

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-2-6 10:27:42 | 显示全部楼层 |阅读模式
一、ROLES 角色
   1、目录层级结构
   2、角色调用
   3、层级结构展示
    示例1:利用ansible角色安装nginx
    示例2:变量调用
    示例3:在playbook调用角色方法:传递变量给角色
    示例4:条件测试角色调用
    示例5:角色安装
    示例6:角色变量调整memcached内存大小

一、ROLES 角色
         对于以上所有的方式有个弊端就是无法实现复用假设在同时部署Web、db、ha 时或不同服务器组合不同的应用就需要写多个yml文件。很难实现灵活的调用。。
         roles 用于层次性、结构化地组织playbook。roles 能够根据层次型结构自动装载变量文件、tasks以及handlers等。要使用roles只需要在playbook中使用include指令即可。简单来讲,roles就是通过分别将变量(vars)、文件(file)、任务(tasks)、模块(modules)及处理器(handlers)放置于单独的目录中,并可以便捷地include它们的一种机制。角色一般用于基于主机构建服务的场景中,但也可以是用于构建守护进程等场景中。
1、目录层级结构
    roles每个角色中,以特定的层级目录进行组织
           Mysql/  角色
                   Files/     #存放有copy或script模块等调用的文件;’
                   Tepmlates/    #template模块查找所需要模板文件目录;
                   Tasks/           #定义任务;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过
    include进行包含。
                   Handlers/      #定义触发器;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过
    include进行包含。
                   Vars/              #定义变量;至少应该包含一个名为main.yml的文件;其他的文件需要在此文件中通过
    include进行包含。
                  Meta/             #定义变量;至少应该包含一个名为main.yml的文件;定义当前角色的特殊设定及其依赖
    关系;其他的文件需要在此文件中通过include进行包含。
                   Default/         #设定默认变量时使用此目录中的main.yml文件。
2、角色调用
1
2
3
4
5
6
7
8
  [iyunv@centos7_1 yaml]# vim roles.yml
   ---
    Hosts:web
   Remote_user:root
   Roles:
   - mysql
   - memchached
   - nginx




3、层级结构展示
          wKioL1iNvDigfDsaAAAfQx5IoMw285.jpg

示例1:利用ansible角色安装nginx

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
[iyunv@centos7_1 ~]# mkdir/etc/ansible/roles/nginx/{files,tasks,templates,handlers,vars, \
default,mata} –pv
#创建固定目录结构
[iyunv@centos7_1 ~]# tree  /etc/ansible/roles/nginx/
/etc/ansible/roles/nginx/
├── default
├── files
├── handlers
├── mata
├── tasks
├── templates
└── vars
[iyunv@centos7_1 ~]# cd/etc/ansible/roles/nginx/
[iyunv@centos7_1 nginx]# vimtasks/main.yml  #创建任务
- name: install nginx package
yum: name=nginx state=present
- name: install conf file
template: src=nginx.conf.j2 dest=/etc/nginx/nginx.conf
#此处源文件可不写绝对路径,系统自查找。
- name: start nginx
service: name=nginx state=started
[iyunv@centos7_1 ~]# cp/apps/work/files/nginx.conf.c6.j2 ../templates/nginx.conf.j2
#将配置文件拷贝至templates目录内。
[iyunv@centos7_1 ~]# cd /apps/yaml/
[iyunv@centos7_1 yaml]# cat roles.yml #创建调用文件
---
- hosts: web
remote_user: root
roles:
- nginx
[iyunv@centos7_1 yaml]#ansible-playbook roles.yml  #利用ansible-playbook执行。



示例2:变量调用
1
2
3
4
5
6
7
8
9
利用定义变量使远程主机的nginx服务运行用户变更为daemon
[iyunv@centos7_1 ~]# vim/etc/ansible/roles/nginx/vars/main.yml
username: daemon
[iyunv@centos7_1 ~]# vim/etc/ansible/roles/nginx/templates/nginx.conf.j2
user {{ username }};  #  将此处原有用户修改为变量
[iyunv@centos7_1 ~]# cd/apps/yaml/
[iyunv@centos7_1 yaml]#ansible-playbook  roles.yml
[iyunv@centos7_1 yaml]#ansible-playbook  -e"username=adm"  roles.yml
#也可以直接利用命令行传递变量参数给剧本文件。



示例3:在playbook调用角色方法:传递变量给角色
1
2
3
4
5
6
7
8
9
[iyunv@centos7_1 yaml]vim roles.yml
---
- hosts:web
  remote_user:root
  roles:
  - {role: nigix, username: nginx }
  #在调用nginx角色是使用变量username:nginx时服务运行用户为nginx
   键role:用于指定角色名称;后续的键值对用户传递变量给角色
[iyunv@centos7_1yaml]# ansible-playbook roles.yml



示例4:条件测试角色调用
1
2
3
4
5
6
7
8
9
   还可以基于条件测试实现角色调用;
[iyunv@centos7_1yaml]vim roles.yml
---
- hosts:web
  remote_user: root
  roles:
{role: nigix, username: nginx ,when: “ansible_distribution_major_version ==’7’”}
#基于条件测试调用变量赋予nginx。
[iyunv@centos7_1 yaml]#ansible-playbook -t instconf  roles.yml



示例5:角色安装
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
[iyunv@centos7_1 ~]# mkdir/etc/ansible/roles/memcached/tasks -pv
[iyunv@centos7_1 ~]# vim  /etc/ansible/roles/memcached/tasks/main.yml
- name: install package
yum: name=memcached state=present
- name: start memecached
service: name=memcached state=started

[iyunv@centos7_1 ~]# cd/apps/yaml/
[iyunv@centos7_1 yaml]# cat mem.yml
---
- hosts: web
  remote_user: root
  roles:
  - { role: nginx,when:ansible_distribution_version == '7' }  
  #系统为centos7时调用执行nginx
  - { role: memcached,when: ansible_hostname =='memcached' }  
  #系统用户名为memcached的主机调用执行角色memcached。



示例6:角色变量调整memcached内存大小
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
利用变量使远程主机上的Memcahed的缓存大小占用系统内存大小的三分之一。
[iyunv@centos7_1 ~]# cd/etc/ansible/roles/memcached/
[iyunv@centos7_1 memcached]#ls
handlers/  tasks/    templates/
[iyunv@centos7_1 memcached]#mkdir  templates
[iyunv@centos7_1memcached]# scp 172.16.254.216:/etc/sysconfig/memcached \
    ./templates//memcached.j2
[iyunv@centos7_1 memcached]#vim templates/memcached.j2
PORT="11211"
USER="memcached"
MAXCONN="1024"
CACHESIZE="{{ansible_memtotal_mb//3 }}"
#变量设置内存的3分之一  此变量为远程主机的总内存//3 指除3取商
  便为远程主机的三分之一
[iyunv@centos7_1 memcached]#mkdir handlers/
[iyunv@centos7_1 memcached]#vim handlers/main.yml
- name: restart memcached
  service: name=memcached state=restarted
[iyunv@centos7_1 memcached]#cd /apps/yaml/
root@centos7_1 yaml]#ansible-playbook   mem.yml  #执行剧本







运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-338175-1-1.html 上篇帖子: Ansible自动化部署之Play book的使用 下篇帖子: ansible自动化部署之第三方模块添加(时间计时模块)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表