标签:eve 组织 jpg handlers code 配置 lamp 验证 use
Roles介绍Ansible为了层次化、结构化地组织Playbook,使用了角色(roles)。Roles能够根据层次型结构自动装载变量文件、task以及handlers等。简单来讲,roles就是通过分别将变量、文件、任务、模块及处理器放置于单独的目录中,并可以便捷地include它们,roles一般用于基于主机构建服务的场景中,但也可以用于构建守护进程等场景中。
创建roles时一般需要以下步骤:首先创建以roles命名的目录。然后在roles目标下分别创建以个角色名称命令的目录,如websevers等,在每个角色命令的目录中分别创建files、handlers、tasks、templates、meta、defaults和vars目录,用不到的目录可以创建为空目录。最后在Playbook文件中调用各角色进行使用
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
vi /etc/ansible/roles/httpd/tasks/main.yml
- name: ensure apache is at the latest version
yum: pkg={{ pkg }} state=latest
- name: copy file
template: src=/etc/ansible/templates/httpd.conf dest=/etc/httpd/conf/httpd.conf
- name: restart httpd server
service: name=httpd enabled=true state=restarted
vi /etc/ansible/roles/httpd/vars/main.yml
pkg: httpd
vi /etc/ansible/roles/mysql/tasks/main.yml
- name: ensure mysql is at the latest version
yum: pkg={{ pkg }} state=latest
vi /etc/ansible/roles/mysql/vars/main.yml
pkg: mariadb*
vi /etc/ansible/roles/php/tasks/main.yml
- name: ensure php is at the latest version
yum: pkg={{ pkg }} state=latest
vi /etc/ansible/roles/php/vars/main.yml
pkg: php
修改监听IP 和域名 设为变量方便其他主机使用这个模块
vi /etc/ansible/site.yml
---
- hosts: xxy
remote_user: root
roles:
- httpd
- mysql
- php
执行:ansible-playbook site.yml
到控制端192.168.1.25上写修改首页内容
echo "<?php phpinfo();?>" > /var/www/html/index.php
systemctl restart httpd
控制端使用浏览器输入:192.168.1.25/index.php测试
标签:eve 组织 jpg handlers code 配置 lamp 验证 use
原文地址:http://blog.51cto.com/13641879/2154966