在强调一遍吧,为什么我再次使用ansible搞定呢?
① 定制剧本
② 基于python实现模块化:
(调用特定模块 ,完成特定任务,支持自定义模块)
整个role目录的结构:
代码语言:javascript复制.
├── ansible.cfg
├── hosts
├── httpd-php_roles.retry
├── httpd-php_roles.yml
├── roles
│ ├── httpd
│ │ ├── files
│ │ │ ├── mysql_wp.sh
│ │ │ ├── wordpress-4.7.4-zh_CN.tar.gz
│ │ │ ├── wordpress.conf
│ │ │ └── wp-config.php
│ │ ├── handlers
│ │ │ └── main.yml
│ │ ├── tasks
│ │ │ └── main.yml
│ │ └── vars
│ ├── mariadb
│ │ ├── defaults
│ │ ├── files
│ │ ├── handlers
│ │ │ └── main.yml
│ │ ├── tasks
│ │ │ └── main.yml
│ │ ├── templetes
│ │ └── vars
│ └── php
│ ├── defaults
│ ├── files
│ ├── handlers
│ ├── meta
│ ├── tasks
│ │ └── main.yml
│ ├── tmpletes
│ └── vars
└── wp-config.php
- 定义hosts目标主机:
vim /etc/ansible/hosts
[httpd]
192.168.5.111
- 创建httpd相关的目录:
mkdir httpd/{tasks,vars,files} -pv
- 进入tasks目录创建并编辑main.yml
---
- name: install httpd
yum: name=httpd state=present
- name: conf httpd
copy: src=wordpress.conf dest=/etc/httpd/conf.d/
- name: file wordpress
copy: src=wordpress-4.7.4-zh_CN.tar.gz dest=/var/www/html
- name: tar wordpress.tar.gz
shell: "tar -xf wordpress-4.7.4-zh_CN.tar.gz && chown -R apache.apache wordpress && mv wordpress-4.7.4-zh_CN.tar.gz /usr/local/src"
args:
chdir: /var/www/html
notify: start httpd #当上面的执行完成后会触发handler定义的同名的动作
- name: conf wp-config.php
copy: src=wp-config.php dest=/var/www/html/wordpress
- name: mysql_wp.sh
script: mysql_wp.sh
notify: restart httpd
- name: restart httpd
service: name=httpd state=restarted
- 将所需的文件放入roles/httpd/files中,文件中的内容下面用到会提及
files/
├── mysql_wp.sh
├── wordpress-4.7.4-zh_CN.tar.gz
├── wordpress.conf
└── wp-config.php
4.1.1 上面定义的数据库需要数据库等需要自行创建,将其写脚本files/mysql_wp.sh文件:
代码语言:javascript复制#!/bin/bash
#
mysql -uroot -e "
CREATE DATABASE IF NOT EXISTS wordpress CHARACTER SET 'utf8';
GRANT ALL ON wordpress.* TO 'wpuser'@'localhost' IDENTIFIED BY 'wppd'; "
4.1.2 wordpress程序需要手动更改一个配置文件,事先编辑好直接推送wordpress/目录下,这就是roles/httpd/files中的wp-conf.php,需要更改内容如下:
代码语言:javascript复制define('DB_NAME', 'wordpress');
/** MySQL数据库用户名 */
define('DB_USER', 'wpuser');
/** MySQL数据库密码 */
define('DB_PASSWORD', 'wppd');
/** MySQL主机 */
define('DB_HOST', 'localhost');
4.1.3 关于httpd.conf 其实就是修改其中几条默认的配置:
参照此链接配置
- 在handlers中编辑main.yml定义触发的动作
---
- name: start httpd
service: name=httpd state=started
- name: restart httpd
service: name=httpd state=restarted
- httpd的已经完成,接下来定义php模块的内容,同样在roles中创建php相关目录:
mkdir php/{tmpletes,tasks,files,handlers,meta,defaults,vars} -pv
- 编辑tasks中的main.yml文件,这里只是安装了一个php模块:
---
- name: install php
yum: name=php state=present
- 定义mariadb相关的内容的目录:
mkdir mariadb/{templetes,handlers,vars,files,defaults,tasks} -vp
- 编辑roles/mariadb/tasks/main.yml文件,顺带安装一下几个模块:
---
- name: install mariadb
yum: name=mariadb-server state=present
- name: install httpd-mysql
yum: name=php-mysql state=present
- name: install php-mbstring
yum: name=php-mbstring state=present
- name: restart mariadb
service: name=mariadb state=restarted
- 与roles同级创建一个yml文件,将这三个项目整合起来运行:
cd /etc/ansible
vim httpd-php_roles.yml
---
- hosts: httpd
remote_user: root
roles:
- { role: php, tags: [ php-tag,ap-tag ] }
- { role: mariadb, tags: [ mariadb-tag,ap-tag ] }
- { role: httpd, tags: [ httpd-tag,ap-tag ] }
- 向定义的目标主机进行发布程序:
~]# ansible-playbook /etc/ansible/httpd-php_roles.yml
只要目标主机yum源可用,没有遇到报错基本OK.