这篇文章主要介绍如何搭建ansible roles,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
在实际的工作当中,一个完整的项目实际上是很多功能体的组合,如果将所有的功能写在一个playbook中会存在如代码耦合程度高、playbook长而维护成本大、灵活性低等一系列的问题。使用roles能巧妙的解决这一系列的问题。roles是ansible1.2版本后加入的新功能,适合于大项目playbook的编排架构。
roles能够根据层次型结构自动装载变量文件、task以及handlers等。简单来讲,roles就是通过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并可以便捷地include它们,roles一般用于基于主机构建服务的场景中,但也可以用于构建守护进程等场景中。 roles/ common/ files/ templates/ tasks/ handlers/ vars/ defaults/ meta/ web/ files/ templates/ tasks/ handlers/ vars/ defaults/ meta/
files:用来存放由copy模块或script模块调用的文件。 templates:用来存放jinjia2模板,template模块会自动在此目录中寻找jinjia2模板文件。 tasks:此目录应当包含一个main.yml文件,用于定义此角色的任务列表,此文件可以使用include包含其它的位于此目录的task文件。 handlers:此目录应当包含一个main.yml文件,用于定义此角色中触发条件时执行的动作。 vars:此目录应当包含一个main.yml文件,用于定义此角色用到的变量。 defaults:此目录应当包含一个main.yml文件,用于为当前角色设定默认变量。 meta:此目录应当包含一个main.yml文件,用于定义此角色的特殊设定及其依赖关系。 在一个playbook中使用roles的步骤: 1)创建以roles命令的目录。 mkdir /etc/ansible/roles/ -p #yum装完默认就有 2)创建全局变量目录。 mkdir /etc/ansible/group_vars/ -p touch /etc/ansible/group_vars/all #文件名自己定义,引用的时候注意 3)在roles目录中分别创建以各角色名称命令的目录,如httpd。 mkdir /etc/ansible/roles/common -p 4)在每个角色命令的目录中分别创建files、handlers、tasks、templates、meta、defaults和vars目录,用不到的目录可以创建为空目录,但不可以不创建。 mkdir /etc/ansible/roles/httpd/{files,templates,tasks,handlers,vars,defaults,meta} -p mkdir /etc/ansible/roles/mysql/{files,templates,tasks,handlers,vars,defaults,meta} -p 5)在每个角色的handlers、tasks、meta、defaults、vars目录下创建main.yml文件,千万不能自定义。 touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yml touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yml 6)在playbook文件中,调用各角色。 vi /etc/ansible/site.yml --- - hosts: webserver remote_user: root roles: - httpd - mysql
[root@localhost ~]# vim /etc/ansible/hosts [ftpserver] 192.168.136.251 #创建目录,子目录 mkdir /etc/ansible/roles/httpd/{files,templates,tasks,handlers,vars,defaults,meta} -p mkdir /etc/ansible/roles/mysql/{files,templates,tasks,handlers,vars,defaults,meta} -p mkdir /etc/ansible/roles/php/{files,templates,tasks,handlers,vars,defaults,meta} -p touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yml touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yml touch /etc/ansible/roles/php/{defaults,vars,tasks,meta,handlers}/main.yml #apachej角色 [root@localhost roles]# cd /etc/ansible/roles/httpd/tasks/ [root@localhost tasks]# vim main.yml - name: install apache yum: pkg={{ servername }} state=latest #定义servername [root@localhost tasks]# cd ../vars/ [root@localhost vars]# vim main.yml servername: httpd #mysql角色 [root@localhost vars]# cd ../../mysql/tasks/ [root@localhost tasks]# vim main.yml - name: install mysqld yum: pkg={{servername}} state=latest [root@localhost tasks]# vim ../vars/main.yml servername: mariadb* #php角色 [root@localhost tasks]# cd ../../php/tasks/ [root@localhost tasks]# vim main.yml - name: install php yum: pkg={{servername}} state=latest [root@localhost tasks]# cd ../vars/ [root@localhost vars]# vim main.yml servername: php #创建总体剧本去控制这些服务 [root@localhost vars]# cd /etc/ansible/ [root@localhost ansible]# vim site.yml - hosts: ftpserver remote_user: root roles: - httpd - mysql - php [root@localhost ansible]# ansible-playbook site.yml PLAY [ftpserver] *********************************************************************************** TASK [Gathering Facts] ***************************************************************************** ok: [192.168.136.251] TASK [httpd : install apache] ********************************************************************** changed: [192.168.136.251] TASK [mysql : install mysqld] ********************************************************************** changed: [192.168.136.251] TASK [php : install php] *************************************************************************** changed: [192.168.136.251] PLAY RECAP ***************************************************************************************** 192.168.136.251 : ok=4 changed=3 unreachable=0 failed=0
以上是“如何搭建ansible roles”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。