【寫在最前】我們在平時的編程學習中,或多或少,或早或晚,都要接觸到linux服務器;當你工作中接觸的服務器比較多(或者你致力于成為一名合格的linux集群運維人員),那么ansible就是你必須要掌握的維護工具!本文致力于成為(或許已經(jīng)是)全網(wǎng)最簡介的ansible工具教程,讓我們花5分鐘時間搞懂a(chǎn)nsible運維工具,相信聰明的你,看完一定會有收獲!
【正文開始】
為什么要用Ansible?
假設(shè)你有100臺服務器,需要先安裝同樣的業(yè)務軟件,再進行相似的配置文件修改,如果靠人工每臺挨個去操作,不僅效率低下,而且極易出錯。
Ansible,就是為Unix/Linux集群運維而生!
什么是Ansible?Ansible是一個集群運維管理工具,這是一款入門非常簡單但是功能卻極其強大的軟件,僅靠SSH就能正常運行各種定制化任務。
跟普通的bash腳本相比,Ansilble有一個非常重要的特點,就是能保證任務操作的“冪等性”(可以重復執(zhí)行任務,并且執(zhí)行結(jié)果保持不變)
# 準備工作(制作SSH免密登錄環(huán)境)
假設(shè): 想通過192.168.1.2登錄 1.3,那么在1.2上執(zhí)行如下兩條命令:ssh-keygen ssh-copy-id [email protected]注1:第1條命令一路回車即可在本地生成密鑰對(在本地/home/xxx/.ssh/下生成兩個文件:id_isa.pub 和 id_rsa)注2:第2條命令是將本地公鑰發(fā)送到1.3上(需要輸入2遍xxx用戶的密碼)
# 安裝 ansible
sudo yum -y install ansible
注:安裝后會自動生成 /etc/ansible 目錄(內(nèi)含 ansible.cfg配置文件)
# 配置(管理)服務器節(jié)點ansible.cfg中第一行配置內(nèi)容為:#inventory = /etc/ansible/hosts這個 inventory 表示是服務器節(jié)點配置文件地址(默認為/etc/ansible/hosts)
當然,你也可以在具體的ansible命令中通過 -i 參數(shù)顯式指定其他配置文件
hosts配置文件內(nèi)容舉例:
[group1]192.168.1.3
192.168.1.4
192.168.1.5
注:這里的group1表示服務器群組的名字,你可以隨便定義
# ansible基本用法:
需求舉例:在遠端N臺服務器上同時安裝nginx軟件實現(xiàn)命令:
ansible -i /etc/ansible/hosts group1 -b –become-user=root -m shell -a ‘yum -y install nginx’
參數(shù)釋義:-i: 指定host服務器配置清單文件的路徑(默認是在/etc/ansible/hosts,可選項)-b: become“成為”,即切換成root用戶去執(zhí)行命令-m: 指定module模塊名稱,比如 ping ,copy 等-a: 用于將參數(shù)傳遞給定義的模塊m
另一個例子:
ansible group1 -m ping
可借助ping模塊實現(xiàn)group1群組所有服務器的網(wǎng)路連通性檢測。
# ansible進階用法:
1)保持操作冪等
聯(lián)想上面的基本語法:
ansible group1 -m shell -a ‘yum -y install nginx’
這種風格有一個缺點:不能保證操作冪等性。
我們來改進一下:
ansible group1 -m yum -a ‘name=nginx state=installed’
執(zhí)行結(jié)果為:
127.0.0.1 | success >> {“changed”: false}
我們看到結(jié)果中有: changed:false 表示遠端服務器已經(jīng)安裝過nginx了,不會再重復安裝
2)使用 playbook劇本、task任務、handler處理程序
playbook劇本可以支持運行多個task任務,并提供一些更高級的功能。
handlers處理程序與task任務基本相同,但只有當另一個任務調(diào)用它時才會運行(例如在服務安裝成功后,再啟動該服務)
在ansible中,劇本相關(guān)的配置都使用Yaml文件定義(必須使用空格縮進,不允許使用tab鍵縮進,故建議將你的IDE工具的tab按鍵輸出替換成4個空格)。 我們繼續(xù)以安裝nginx并啟動nginx為例進行講解: 定義劇本:
nginx.yml 內(nèi)容如下:
– hosts: group1become: yesbecome_user: roottasks:- name: “安裝nginx”yum:pkg: nginxstate: installedwhen: successnotify:- Start Nginx handlers:- name: Start Nginxservice:name: nginxstate: started
運行劇本:
$ ansible-playbook nginx.yml
此時,hosts集群配置文件中的group1群組下的3臺服務器上的nginx軟件,就已經(jīng)全部裝好啦。
【全文完】——————————–十年技術(shù)沉淀,只做原創(chuàng)文章;及時關(guān)注作者,成就大牛之路!如果您對文章內(nèi)容有不同意見或獨到見解,歡迎大家在評論區(qū)留言討論,作者也會第一時間進行互動回復。