roles 介绍
roles 就是通过分别将 variables,tasks 及 handlers 等放置于单独的目录中,并可以便捷地调用它们的一种机制。
假设我们要写一个 playbook 来安装管理 lamp 环境,那么这个 playbook 就会写很长。所以我们希望把这个很大的文件分成多个功能拆分,分成 apache 管理,php 管理,mysql 管理,然后在需要使用的时候直接调用就可以了,以免重复写。就类似编程里的模块化的概念,以达到代码复用的效果。
roles 目录结构
files: 用来存放由 copy 模块或 script 模块调用的文件。
tasks: 至少有一个 main.yml 文件,定义 tasks。
handlers: 有一个 main.yml 文件,定义 handlers。
templates: 用来存放 jinjia2 模板。
vars: 有一个 main.yml 文件,定义变量。
meta: 有一个 main.yml 文件,定义此角色的特殊设定及其依赖关系。
注意: 在每个角色的目录中分别创建 files,tasks,handlers,templates,vars 和 meta 目录,用不到的目录可以创建为空目录。
roles 实现 lamp
需定制三个 role:httpd,mysql,php
第1步: 创建 roles 目录及文件,并确认目录结构
[root@localhost ~]# cd /etc/ansible/roles/
[root@localhost roles]# mkdir -p {httpd,mysql,php}/{files,tasks,handlers,templates,vars,meta}
[root@localhost roles]# touch {httpd,mysql,php}/{tasks,handlers,vars,meta}/main.yml
[root@localhost roles]# touch lamp.yml
[root@localhost roles]# tree -C
.
├── httpd
│ ├── files
│ │ ├── httpd.conf
│ │ ├── index.html
│ │ └── index.php
│ ├── handlers
│ │ └── main.yml
│ ├── meta
│ │ └── main.yml
│ ├── tasks
│ │ └── main.yml
│ ├── templates
│ └── vars
│ └── main.yml
├── lamp.yml
├── mysql
│ ├── files
│ ├── handlers
│ │ └── main.yml
│ ├── meta
│ │ └── main.yml
│ ├── tasks
│ │ └── main.yml
│ ├── templates
│ └── vars
│ └── main.yml
└── php
├── files
├── handlers
│ └── main.yml
├── meta
│ └── main.yml
├── tasks
│ └── main.yml
├── templates
└── vars
└── main.yml
第2步: 准备 httpd 服务器的主页文件,php 测试页和配置文件等
[root@localhost roles]# echo 'test page' > httpd/files/index.html
[root@localhost roles]# echo -e '<?php\n\tphpinfo();\n?>' > httpd/files/index.php
[root@localhost roles]# cp /etc/httpd/conf/httpd.conf httpd/files/httpd.conf
第3步: 编写 httpd 角色的 main.yml 文件
[root@localhost roles]# vim httpd/tasks/main.yml
---
- name: 安装 httpd
yum: name=httpd
- name: 同步 httpd.conf 配置
copy: src=httpd.conf dest=/etc/httpd/conf/httpd.conf
notify: restart httpd
- name: 同步主页文件
copy: src=index.html dest=/var/www/html/index.html
- name: 同步测试文件
copy: src=test.php dest=/var/www/html/index.php
- name: 启动 httpd 并设置开机自启
service: name=httpd state=started enabled=yes
第4步: 编写 httpd 角色里的 handler 文件
[root@localhost roles]# vim httpd/handlers/main.yml
- name: restart httpd
service: name=httpd state=restarted
第5步: 编写 mysql 角色的 main.yml 文件
[root@localhost roles]# vim mysql/tasks/main.yml
---
- name: 安装mysql
yum: name=mariadb,mariadb-server,mariadb-devel state=present
- name: 启动mysql并开机自启动
service: name=mariadb state=started enabled=yes
第6步: 编写 php 角色的 main.yml 文件
[root@localhost roles]# vim php/tasks/main.yml
---
- name: 安装 php 及依赖包
yum: name=php,php-gd,php-ldap,php-odbc,php-pear,php-xml,php-xmlrpc,php-mbstring,php-snmp,php-soap,curl,curl-devel,php-bcmath,php-mysql state=present
notify: restart httpd
第7步:编写 lamp 的 playbook 文件调用前面定义好的三个角色
[root@localhost roles]# vim lamp.yml
- hosts: group1
remote_user: root
roles:
- httpd
- mysql
- php
第8步: 执行lamp的playbook文件
[root@localhost roles]# ansible-playbook lamp.yml