=================================================================
往期Ansible目录
==========================================================================
-
编写playbook有个弊端就是无法实现复用
-
假设在同时部署Web、db、ha 时或不同服务器组合不同的应用就需要写多个yml文件。很难实现灵活的调用。。
-
roles 用于层次性、结构化地组织playbook。roles能够根据层次型结构自动装载变量文件、tasks以及handlers等。
-
要使用roles只需要在playbook中使用include指令即可。
-
简单来讲,roles就是通过分别将变量(vars)、文件(file)、任务(tasks)、模块(modules)及处理器(handlers)放置于单独的目录中,并可以便捷地include它们的一种机制。
-
角色一般用于基于主机构建服务的场景中,但也可以是用于构建守护进程等场景中。
=======================================================================
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文件。
==========================================================================
#创建固定目录结构
[root@ansible roles]# tree
.
├── httpd
│ ├── files
│ │ └── httpd.conf
│ └── tasks
│ ├── copyfile.yml
│ ├── main.yml
│ └── user.yml
├── memcache
├── mysql
└── nginx
├── main.yml
├── tasks
│ ├── group.yml
│ ├── restart.yml
│ ├── start.yml
│ ├── user.yml
│ └── yum.yml
└── templates
8 directories, 10 files
[root@ansible roles]# cd nginx/
#定义执行的顺序
[root@ansible nginx]# cat main.yml
-
include: group.yml
-
include: user.yml
-
include: yum.yml
-
include: start.yml
最后的话
最近很多小伙伴找我要Linux学习资料,于是我翻箱倒柜,整理了一些优质资源,涵盖视频、电子书、PPT等共享给大家!
资料预览
给大家整理的视频资料:
给大家整理的电子书资料:
如果本文对你有帮助,欢迎点赞、收藏、转发给朋友,让我有持续创作的动力!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
技术提升。**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!