Ansible roles實現LAMP部署wordpress

ansible lamp

ansible roles實現lamp安裝wordpress

整個role目錄的結構:

.
├── 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

1.定義hosts目標主機:

vim /etc/ansible/hosts
[httpd]
192.168.5.111

2.創建httpd相關的目錄:

mkdir httpd/{tasks,vars,files} -pv

3.進入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

4.將所需的文件放入roles/httpd/files中,文件中的內容下面用到會提及

files/
├── mysql_wp.sh
├── wordpress-4.7.4-zh_CN.tar.gz
├── wordpress.conf
└── wp-config.php

5.在handlers中編輯main.yml定義觸發的動作

---
- name: start httpd
  service: name=httpd state=started
- name: restart httpd
  service: name=httpd state=restarted

6.httpd的已經完成,接下來定義php模塊的內容,同樣在roles中創建php相關目錄:

mkdir php/{tmpletes,tasks,files,handlers,meta,defaults,vars} -pv

7.編輯tasks中的main.yml文件,這裏只是安裝了一個php模塊:

---
- name: install php
  yum: name=php state=present

8.定義mariadb相關的內容的目錄:

mkdir mariadb/{templetes,handlers,vars,files,defaults,tasks} -vp

9.編輯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

10.wordpress程序需要手動更改一個配置文件,事先編輯好直接推送wordpress/目錄下,這就是roles/httpd/files中的wp-conf.php,需要更改內容如下:

define('DB_NAME', 'wordpress');

/** MySQL數據庫用戶名 */
define('DB_USER', 'wpuser');

/** MySQL數據庫密碼 */
define('DB_PASSWORD', 'wppd');

/** MySQL主機 */
define('DB_HOST', 'localhost');

11.上面定義的數據庫需要數據庫等需要自行創建,將其寫腳本files/mysql_wp.sh文件:

#!/bin/bash
#
mysql -uroot -e " 
        CREATE DATABASE IF NOT EXISTS wordpress CHARACTER  SET 'utf8';
        GRANT ALL ON wordpress.* TO 'wpuser'@'localhost' IDENTIFIED BY 'wppd'; "

12.與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 ] }

13.向定義的目標主機進行發佈程序:

~]# ansible-playbook /etc/ansible/httpd-php_roles.yml

只要目標主機yum源可用,沒有遇到報錯基本OK.

wKiom1li5crht903AAC6Wx9a130810.png-wh_50

訪問驗證一下:

wKiom1li5ePy-OcIAADWPHjkPlo654.png-wh_50

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章