ansible-role 安裝httpd服務(wù)

想上傳個(gè)ansible目錄結(jié)構(gòu)圖的,但是不知道咋的就上傳圖片就失敗,所以各位自行百度ansible的目錄結(jié)構(gòu)圖吧,不過(guò)下邊的文字解釋也足夠讓你理解ansible的目錄結(jié)構(gòu)即日常使用了。

ansible 各目錄含義解釋

roles:          <--所有的角色必須放在roles目錄下,這個(gè)目錄可以自定義位置,默認(rèn)的位置在/etc/ansible/roles
  project:      <---具體的角色項(xiàng)目名稱,比如nginx、tomcat、php
    files:     <--用來(lái)存放由copy模塊或script模塊調(diào)用的文件。
    templates: <--用來(lái)存放jinjia2模板,template模塊會(huì)自動(dòng)在此目錄中尋找jinjia2模板文件。
    tasks:     <--此目錄應(yīng)當(dāng)包含一個(gè)main.yml文件,用于定義此角色的任務(wù)列表,此文件可以使用include包含其它的位于此目錄的task文件。
      main.yml
      install.yml ... #根據(jù)實(shí)際情況編寫 這里只是示例
      user.yml ... #根據(jù)實(shí)際情況編寫 這里只是示例
    handlers:  <--此目錄應(yīng)當(dāng)包含一個(gè)main.yml文件,用于定義此角色中觸發(fā)條件時(shí)執(zhí)行的動(dòng)作。
      main.yml
    vars:      <--此目錄應(yīng)當(dāng)包含一個(gè)main.yml文件,用于定義此角色用到的變量。
      main.yml
    defaults:  <--此目錄應(yīng)當(dāng)包含一個(gè)main.yml文件,用于為當(dāng)前角色設(shè)定默認(rèn)變量。
      main.yml
    meta:      <--此目錄應(yīng)當(dāng)包含一個(gè)main.yml文件,用于定義此角色的特殊設(shè)定及其依賴關(guān)系。
      main.yml

Roles 安裝httpd服務(wù)

roles的路徑使用默認(rèn)的/etc/ansible/roles

一、創(chuàng)建基礎(chǔ)目錄

[root@ansible ~]# cd /etc/ansible/roles/    
[root@ansible roles]# mkdir -p httpd/{handlers,tasks,templates,vars}   # 創(chuàng)建需要用到的目錄
[root@ansible roles]# cd httpd/
[root@ansible httpd]# tree .
.
├── handlers          #此目錄應(yīng)當(dāng)包含一個(gè)main.yml文件,用于定義此角色中觸發(fā)條件時(shí)執(zhí)行的動(dòng)作。
├── tasks             #存放具體的執(zhí)行任務(wù) 比如安裝 啟動(dòng)等
├── templates         #用來(lái)存放jinjia2模板,template模塊會(huì)自動(dòng)在此目錄中尋找jinjia2模板文件。 那么這里這次存放的是httpd的配置文件
└── vars              #存放變量

4 directories, 0 file

二、編寫變量文件 vars/main.yml

[root@ansible httpd]# vim vars/main.yml
PORT: 8088        #指定httpd監(jiān)聽的端口
USERNAME: www     #指定httpd運(yùn)行用戶
GROUPNAME: www    #指定httpd運(yùn)行組

三、配置文件模板準(zhǔn)備 templates/httpd.conf.j2

# copy一個(gè)本地的配置文件放在templates/下并已j2為后綴
[root@ansible httpd]# cp /etc/httpd/conf/httpd.conf templates/httpd.conf.j2

# 進(jìn)行一些修改,調(diào)用上面定義的變量
[root@ansible httpd]# vim templates/httpd.conf.j2
Listen {{ PORT }} 
User {{ USERNAME }}
Group {{ GROUPNAME }}

四、任務(wù)劇本編寫,包括創(chuàng)建用戶,創(chuàng)建用戶組,安裝軟件,配置,啟動(dòng)等

創(chuàng)建組的task
[root@ansible httpd]# vim tasks/group.yml
- name: Create a Startup Group
  group: name=www gid=60 system=yes
創(chuàng)建用戶的task
[root@ansible httpd]# vim tasks/user.yml
- name: Create Startup Users
  user: name=www uid=60 system=yes shell=/sbin/nologin
安裝軟件的task
[root@ansible httpd]# vim tasks/install.yml
- name: Install Package Httpd
  yum: name=httpd state=installed
配置軟件的task
[root@ansible httpd]# vim tasks/config.yml
- name: Copy Httpd Template File
  template: src=httpd.conf.j2 dest=/etc/httpd/conf/httpd.conf
  notify: Restart Httpd
啟動(dòng)軟件的task
[root@ansible httpd]# vim tasks/start.yml
- name: Start Httpd Service
  systemd: name=httpd state=started enabled=yes
編寫main.yml,將上面的這些task引入進(jìn)來(lái)
[root@ansible httpd]# vim tasks/main.yml
- include: group.yml
- include: user.yml
- include: install.yml
- include: config.yml
- include: start.ym

五、編寫重啟httpd的handlers, handlers/main.yml

[root@ansible httpd]# vim handlers/main.yml
# 這里的名字需要和task中的notify保持一致
- name: Restart Httpd
  systemd: name=httpd state=restarted

六、編寫主的httpd_roles.yml 文件調(diào)用httpd角色

[root@ansible httpd]# cd ..
[root@ansible roles]# vim httpd_roles.yml
---
- hosts: all
  remote_user: root
  roles:
    - role: httpd        #指定角色名稱

七、整體的一個(gè)目錄結(jié)構(gòu)查看

[root@ansible roles]# tree .
.
├── httpd
│   ├── handlers
│   │   └── main.yml
│   ├── tasks
│   │   ├── config.yml
│   │   ├── group.yml
│   │   ├── install.yml
│   │   ├── main.yml
│   │   ├── start.yml
│   │   └── user.yml
│   ├── templates
│   │   └── httpd.conf.j2
│   └── vars
│       └── main.yml
└── httpd_roles.yml

5 directories, 10 files

八、測(cè)試執(zhí)行角色

[root@ansible roles]# ansible-playbook -C httpd_roles.yml 

九、正式執(zhí)行

[root@ansible roles]# ansible-playbook httpd_roles.yml 

安裝完成總結(jié):

1.中間測(cè)試的時(shí)候有報(bào)幾個(gè)錯(cuò),都是因?yàn)榇中拇笠庠斐?,比如?chuàng)建用戶和創(chuàng)建用戶組的system模塊,我寫成了systemctl,還有開機(jī)自啟動(dòng)enabled 我寫成了enable 這個(gè)報(bào)錯(cuò)的話,測(cè)試執(zhí)行的時(shí)候會(huì)報(bào)出來(lái),可以先翻譯為中文的,再看一遍英文的,有時(shí)候會(huì)明顯的看出來(lái)你哪個(gè)寫錯(cuò)了。

2.跟寫單獨(dú)的劇本不一樣的是,編寫任務(wù)(task)下的所有文件,都不用指定執(zhí)行的主機(jī),且一個(gè)文件一個(gè)任務(wù),安裝就是安裝,啟動(dòng)就是啟動(dòng),單獨(dú)做一件事即可,這樣看文件名即可一目了然,且方便后期維護(hù)和復(fù)制到其他地方復(fù)用,最后通過(guò)main.yml 將這些單獨(dú)的任務(wù)安裝執(zhí)行順序include進(jìn)來(lái)即可。

3、定義handlers時(shí)候,直接在handlers/main.yml文件中寫需要做什么事情即可,多可的話可以全部寫在該文件里面,也可以像task那樣分開來(lái)寫,通過(guò)include引入一樣的可以。在task調(diào)用notify時(shí)直接寫與handlers名字對(duì)應(yīng)即可(二者必須高度一直)。

4、模板文件一樣放在templates目錄下即可,task調(diào)用的時(shí)后直接寫文件名字即可,會(huì)自動(dòng)去到templates里面找。注意:如果是一個(gè)角色調(diào)用另外一個(gè)角色的單個(gè)task時(shí)后,那么task中如果有些模板或者文件,就得寫絕對(duì)路徑了。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容