这篇文章为大家分享Roles的使用以及Roles安装部署LAMP架构。文章内容包括Roles的简介、Roles的使用方法以及Roles安装部署LAMP架构,希望大家通过这篇文章能有所收获。
Roles的概述
Roles能够根据层次型结构自动装载变量文件、task以及handlers等。
简单来讲,Roles就是通过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并可以便捷地include它们。
Roles一般用于基于主机构建服务的场景中,但也可以用于构建守护进程等场景中。
Roles的目录
目录名称 | 具体含义 |
---|---|
files | 用来存放由copy模块或script模块调用的文件 |
templates | 用来存放j正则模板,template模块会自动在此目录中寻找正则模板文件 |
tasks | 此目录应当包含一个main.yml文件,用于定义此角色的任务列表,此文件可以使用include包含其它的位于此目录的task文件 |
handlers | 此目录应当包含一个main.yml文件,用于定义此角色中触发条件时执行的动作 |
vars | 此目录应当包含一个main.yml文件,用于定义此角色用到的变量 |
defaults | 此目录应当包含一个main.yml文件,用于为当前角色设定默认变量 |
Meta | 此目录应当包含一个main.yml文件,用于定义此角色的特殊设定及其依赖关系 |
在playbook中使用Roles的步骤
- 创建以roles命令的目录
#yum装完默认就有
mkdir /etc/ansible/roles/ -p
- 创建全局变量目录
mkdir /etc/ansible/group_vars/ -p
touch /etc/ansible/group_vars/all
#文件名自己定义,引用的时候注意
- 在roles目录中分别创建以各角色名称命令的目录,如httpd
mkdir /etc/ansible/roles/common -p
- 在每个角色命令的目录中分别创建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
touch /etc/ansible/roles/httpd/{defaults,vars,tasks,Meta,handlers}/main.yml
touch /etc/ansible/roles/MysqL/{defaults,vars,tasks,Meta,handlers}/main.yml
vim /etc/ansible/site.yml
- hosts: webserver
remote_user: root
roles:
- httpd
- MysqL
安装搭建LAMP架构实例演示
- 创建服务组件工作目录
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
- 创建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
touch /etc/ansible/roles/PHP/{defaults,vars,tasks,Meta,handlers}/main.yml
- 编写httpd模块
#写一个简单的tasks/main.yml
vim /etc/ansible/roles/httpd/tasks/main.yml
- name: ensure apache is at the latest version
yum: pkg={{ pkg }} state=latest
#定义变量,可以定义在全局变量中,也可以定义在roles角色变量中,一般定义在角色变量中
vim /etc/ansible/roles/httpd/vars/main.yml
pkg: httpd
- 编写MysqL模块
vim /etc/ansible/roles/MysqL/tasks/main.yml
- name: ensure MysqL is at the latest version
yum: pkg={{ pkg }} state=latest
#定义变量
vim /etc/ansible/roles/MysqL/vars/main.yml
pkg: mariadb*
- 编写PHP模块
vim /etc/ansible/roles/PHP/tasks/main.yml
- name: ensure PHP is at the latest version
yum: pkg={{ pkg }} state=latest
#定义变量
vim /etc/ansible/roles/PHP/vars/main.yml
pkg: PHP*
- 编写roles实例
vim /etc/ansible/site.yml
- hosts: webserver
remote_user: root
roles:
- httpd
- MysqL
- PHP
#执行剧本
ansible-playbook site.yml
执行完以后在远程主机上,查询验证指定服务是否安装
rpm -q httpd
httpd-2.4.6-90.el7.centos.x86_64
rpm -q mariadb
mariadb-5.5.64-1.el7.x86_64
rpm -q PHP
PHP-5.4.16-46.1.el7_7.x86_64
看完上述内容,你们对Roles的使用方法有进一步的了解吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程之家行业资讯频道,感谢各位的阅读!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。