久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

如何搭建ansible roles

155次閱讀
沒有評論

共計 4003 個字符,預計需要花費 11 分鐘才能閱讀完成。

這篇文章主要介紹如何搭建 ansible roles,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

ansible roles

在實際的工作當中,一個完整的項目實際上是很多功能體的組合,如果將所有的功能寫在一個 playbook 中會存在如代碼耦合程度高、playbook 長而維護成本大、靈活性低等一系列的問題。使用 roles 能巧妙的解決這一系列的問題。roles 是 ansible1.2 版本后加入的新功能,適合于大項目 playbook 的編排架構。

ansible roles 目錄結構

roles 能夠根據層次型結構自動裝載變量文件、task 以及 handlers 等。簡單來講,roles 就是通過分別將變量、文件、任務、模塊及處理器放置于單獨的目錄中,并可以便捷地 include 它們,roles 一般用于基于主機構建服務的場景中,但也可以用于構建守護進程等場景中。roles/
 common/
 files/
 templates/
 tasks/
 handlers/
 vars/
 defaults/
 meta/
 web/
 files/
 templates/
 tasks/
 handlers/
 vars/
 defaults/
 meta/

roles 內各目錄含義解釋

files:用來存放由 copy 模塊或 script 模塊調用的文件。templates:用來存放 jinjia2 模板,template 模塊會自動在此目錄中尋找 jinjia2 模板文件。tasks:此目錄應當包含一個 main.yml 文件,用于定義此角色的任務列表,此文件可以使用 include 包含其它的位于此目錄的 task 文件。handlers:此目錄應當包含一個 main.yml 文件,用于定義此角色中觸發條件時執行的動作。vars:此目錄應當包含一個 main.yml 文件,用于定義此角色用到的變量。defaults:此目錄應當包含一個 main.yml 文件,用于為當前角色設定默認變量。meta:此目錄應當包含一個 main.yml 文件,用于定義此角色的特殊設定及其依賴關系。在一個 playbook 中使用 roles 的步驟:1)創建以 roles 命令的目錄。mkdir /etc/ansible/roles/ -p #yum 裝完默認就有
2)創建全局變量目錄。mkdir /etc/ansible/group_vars/ -p
touch /etc/ansible/group_vars/all # 文件名自己定義,引用的時候注意
3)在 roles 目錄中分別創建以各角色名稱命令的目錄,如 httpd。mkdir /etc/ansible/roles/common -p
4)在每個角色命令的目錄中分別創建 files、handlers、tasks、templates、meta、defaults 和 vars 目錄,用不到的目錄可以創建為空目錄,但不可以不創建。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
5)在每個角色的 handlers、tasks、meta、defaults、vars 目錄下創建 main.yml 文件,千萬不能自定義。touch /etc/ansible/roles/httpd/{defaults,vars,tasks,meta,handlers}/main.yml
touch /etc/ansible/roles/mysql/{defaults,vars,tasks,meta,handlers}/main.yml
6)在 playbook 文件中,調用各角色。vi /etc/ansible/site.yml
- hosts: webserver
 remote_user: root
 roles:
 - httpd
 - mysql

角色管理,roles 安裝搭建 LAMP 架構

[root@localhost ~]# vim /etc/ansible/hosts 
[ftpserver]
192.168.136.251
#創建目錄,子目錄
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
#apachej 角色
[root@localhost roles]# cd /etc/ansible/roles/httpd/tasks/
[root@localhost tasks]# vim main.yml 
- name: install apache
 yum: pkg={{ servername }} state=latest
#定義 servername
[root@localhost tasks]# cd ../vars/
[root@localhost vars]# vim main.yml 
servername: httpd
#mysql 角色
[root@localhost vars]# cd ../../mysql/tasks/
[root@localhost tasks]# vim main.yml 
- name: install mysqld
 yum: pkg={{servername}} state=latest
[root@localhost tasks]# vim ../vars/main.yml 
servername: mariadb*
#php 角色
[root@localhost tasks]# cd ../../php/tasks/
[root@localhost tasks]# vim main.yml 
- name: install php
 yum: pkg={{servername}} state=latest
 [root@localhost tasks]# cd ../vars/
[root@localhost vars]# vim main.yml 
 servername: php
#創建總體劇本去控制這些服務
[root@localhost vars]# cd /etc/ansible/
[root@localhost ansible]# vim site.yml
 - hosts: ftpserver
 remote_user: root
 roles:
 - httpd
 - mysql
 - php
 [root@localhost ansible]# ansible-playbook site.yml 
 PLAY [ftpserver] ***********************************************************************************
TASK [Gathering Facts] *****************************************************************************
ok: [192.168.136.251]
TASK [httpd : install apache] **********************************************************************
changed: [192.168.136.251]
TASK [mysql : install mysqld] **********************************************************************
changed: [192.168.136.251]
TASK [php : install php] ***************************************************************************
changed: [192.168.136.251]
PLAY RECAP *****************************************************************************************
192.168.136.251 : ok=4 changed=3 unreachable=0 failed=0

以上是“如何搭建 ansible roles”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注丸趣 TV 行業資訊頻道!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-08-25發表,共計4003字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 山东| 怀远县| 阿巴嘎旗| 巩义市| 邓州市| 四会市| 灌云县| 宁波市| 河间市| 峨山| 黄陵县| 万年县| 遵义市| 鄂州市| 崇左市| 玉树县| 丹寨县| 湘阴县| 化德县| 衢州市| 临江市| 察隅县| 阳谷县| 门源| 察哈| 阳城县| 桓仁| 尼勒克县| 怀安县| 萍乡市| 承德市| 洛宁县| 崇明县| 延吉市| 黄大仙区| 察隅县| 富顺县| 绥棱县| 容城县| 天长市| 香河县|