Ansible 用 Roles 部署 TestLink

2018-07-25 11:03 更新

上一章「Ansible 用 Roles 部署 LNMP 網(wǎng)頁應(yīng)用程式(下)」我們用了 3 個 Roles 和自己寫的 Playbook 部署 Testlink 網(wǎng)頁應(yīng)用程式,接下來凍仁會透過 Roles 展示最精簡的 Playbooks。

automate_with_ansible_practice-27.jpg

chusiang.testlink 是什么?

chusiang.testlink 是部署 TestLink 1.9.15 到 Ubuntu 14.04 和 Debian 8 的 Role,并建置在 Nginx 1.10, PHP 7 和 MySQL 5.6 的環(huán)境上。

凍仁先前幫公司架設(shè) TestLink 時,在 Ansible Galaxy 和 Chef Supermarket 上找不到現(xiàn)成 Roles 和 Cookbooks,索性就自己寫一個。

2016-12-24-chusiang-testlink-role.png

怎么用 Roles 撰寫最精簡的 Playbooks?

看下去之前,可以先回顧上章,比比看兩者的差異。

使用 Vagrant 建立開發(fā)環(huán)境

建立 Vagrantfile 檔案。

$ vi Vagrantfile
# -*- mode: ruby -*-

Vagrant.configure("2") do |config|
  config.vm.box = "ubuntu/trusty64"
  config.vm.network "private_network", ip: "192.168.33.10"
  config.vm.provider "virtualbox" do |vb|
    vb.memory = "1024"
  end
  config.vm.provision "ansible" do |ansible|
    ansible.playbook = "setup.yml"
    ansible.sudo = true
    #ansible.verbose = "vvv"
  end
end

# vi: set ft=ruby :

從 Galaxy 下載 Roles

  1. 建立 requirements.yml,與上章相比多了 chusiang.testlink role。

    $ vi requirements.yml
    # Nginx 1.10
    - src: williamyeh.nginx
     path: roles/
    
    # PHP 7
    - src: chusiang.php7
     path: roles/
    
    # MySQL 5.6
    - src: geerlingguy.mysql
     path: roles/
    
    # TestLink 1.9.15
    - src: chusiang.testlink
     path: roles/
    
  2. 借由 requirements.yml 下載多個 Roles。

    $ ansible-galaxy install -f -p roles -r requirements.yml
    

撰寫 Playbooks

為便于解說,凍仁將于以下范例加上行號,其原始檔可在 lab/ch24/testlink/setup.yml 取得。

$ vi setup.yml
01 #!/usr/bin/env ansible-playbook
02 
03 ---
04 - name: deploy testlink with chusiang.testlink role
05   hosts: all
06   become: true
07 
08   roles:
09     - williamyeh.nginx
10     - chusiang.php7
11     - geerlingguy.mysql
12     - chusiang.testlink
13 
14   tasks:
15     - name: include check task
16       include: roles/chusiang.testlink/tasks/check.yml
17 
18   post_tasks:
19     # Run some tests.
20     - include: roles/chusiang.testlink/tests/curl_testlink_web.yml
21 
22 # vim:ft=ansible:
  • 在第 8-12 行里,載入了 Nginx, MySQL, PHP 和 TestLink 的 Roles。
  • 第 23 行之后的兩個 tasks 是可省略的,這里只是為了驗(yàn)證部署狀態(tài)而使用。

精簡版的 TestLink Playbooks 檔案結(jié)構(gòu)

把 Playbooks 都封裝成 Roles 之后,可明顯看出整體的檔案結(jié)構(gòu)比上章簡潔許多。

$ tree -L 2
.
├── Makefile
├── Vagrantfile
├── ansible.cfg
├── hosts
├── requirements.yml
├── roles
│   ├── chusiang.php7
│   ├── chusiang.testlink
│   ├── geerlingguy.mysql
│   └── williamyeh.nginx
└── setup.yml

5 directories, 6 files

執(zhí)行 Playbooks

  1. 啟用虛擬機(jī)并執(zhí)行 Playbook。

    $ vagrant up
    

    2016-12-24-ansible-testlink-1.gif

  2. 執(zhí)行完畢后,開啟瀏覽器 (Browsers) 并進(jìn)入 TestLink 網(wǎng)站 (http://192.168.33.10),其帳號密碼皆為 admin。

    2016-12-23-ansible-testlink-2.gif

以上,這次我們只需維護(hù) ansible.cfghostsrequirements.yml 和 setup.yml,剩下就交給 Roles 吧!

后話

在完成這篇文章的同時,凍仁也順手修了一下 chusiang.testlink role 的小小 bug。相信當(dāng)越多人分享 Roles 到 Galaxy 后,我們可以減少重復(fù)性質(zhì)的工作,并把時間和精力留在更重要的事情上。

相關(guān)連結(jié)


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號