運(yùn)維管理器Fabric使用方法
Fabric的安裝
Fabric支持pip,easy_install或源碼方式安裝,很方便解決包依賴問(wèn)題,(根據(jù)用戶環(huán)境,自行選擇pip或ease_install)
pip install fabric
easy_install fabric
源碼安裝不介紹了。
校驗(yàn)安裝結(jié)果,如果導(dǎo)入模塊沒(méi)有提示異常,則說(shuō)明安裝成功:
root@Python_S6:~# python
Python 2.7.5+ (default, Sep 19 2013, 13:48:49)
[GCC 4.8.1] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import fabric
>>>
官網(wǎng)提供了一個(gè)簡(jiǎn)單的入門(mén)示例:
root@Python_S6:/home/chart7/test/fabric# cat farbic.py #!/usr/bin/env python # -*- coding: utf-8 -*- from fabric.api import run def host_type(): #定義一個(gè)任務(wù)函數(shù),通過(guò)run方法實(shí)現(xiàn)遠(yuǎn)程執(zhí)行'uname -s'命令 run('uname -s')
運(yùn)行結(jié)果如果下圖所示
命令引用默認(rèn)文件名為fabfile.py,如果使用非默認(rèn)文件名稱,則需通過(guò)'-f'來(lái)制定,如:fab -H 192.168.1.23,192.168.1.24 -f host_type.py host_type,如果管理機(jī)與目標(biāo)主機(jī)未配置密鑰認(rèn)證信任,將提示會(huì)輸入目標(biāo)主機(jī)對(duì)應(yīng)賬戶登錄密碼。
一、fab的常用參數(shù)
fab作為Fabric程序的命令入口,提供了豐富的參數(shù)調(diào)用,命令格式如下:
fab [options] <command>[:arg1,arg2=val2,host=foo,hosts='h1;h2',....]
下面列舉了常用的幾個(gè)參數(shù),更多參數(shù)可使用fab -help查看.
-l,顯示定義好的任務(wù)函數(shù)名;
-f,指定fab入口文件,默認(rèn)入口文件名為fabfile.py;
-g,指定網(wǎng)關(guān)設(shè)備,比如堡壘機(jī)環(huán)境,填寫(xiě)堡壘機(jī)IP即可;
-H,指定目標(biāo)主機(jī),多臺(tái)主機(jī)用','號(hào)分隔;
-P,以異步并行方式運(yùn)行多個(gè)主機(jī)任務(wù),默認(rèn)為串行運(yùn)行;
-R,指定role(角色),以角色名區(qū)分不同業(yè)務(wù)組設(shè)備;
-t,設(shè)置設(shè)備連接超時(shí)時(shí)間;
-T,設(shè)置遠(yuǎn)程主機(jī)命令執(zhí)行超時(shí)時(shí)間;
-w,當(dāng)命令執(zhí)行失敗,發(fā)出警告,而非默認(rèn)終止任務(wù)
二、fabfile的編寫(xiě)
fab命令是結(jié)合我們編寫(xiě)的fabfile.py(其他文件名必須添加-f filename引用)來(lái)搭配使用,部分命令行參數(shù)可以通過(guò)相應(yīng)的方法來(lái)代替,使之更加靈活,列如"-H 192.168.1.23,192.168.1.24",我們可以通過(guò)定義env.hosts來(lái)實(shí)現(xiàn),如"env.hosts=[192.168.1.23,192.168.1.24]".fabfile的主體由多個(gè)自定義的任務(wù)函數(shù)組成,不同任務(wù)函數(shù)實(shí)現(xiàn)不同的操作邏輯,下面詳細(xì)介紹
三、全局屬性設(shè)定
env對(duì)象的作用是定義fabfile的全局設(shè)定,支持多個(gè)屬性,包括目標(biāo)主機(jī),用戶,密碼角色,各屬性說(shuō)明如下:
env.host,定義目標(biāo)主機(jī),可以用IP或主機(jī)名表示,以Python的列表形式定義,如env.hosts=['192.168.1.23,192.168.1.24'].
env.exculde_hosts,排除指定主機(jī),如env.exclude_hosts=['192.168.1.23']
env.user,定義用戶名,如env.user="root"
env.port,定義目標(biāo)主機(jī)端口,如env.port = '22'
env.password,定義密碼,如env.password='123456'
env.passwords,與password功能一樣,區(qū)別在于不同主機(jī)不同密碼的應(yīng)用場(chǎng)景,需要注意的是,配置passwords時(shí)需要配置用戶,主機(jī),端口等信息,如:env.passwords = {'root@192.168.1.21:22':'123456',
'root@192.168.1.23:22':'3234234',
'root@192.168.1.24:23':'09887',
}
env.gateway,定義網(wǎng)關(guān)(中轉(zhuǎn),堡壘機(jī))IP,如env.gateway = '192.168.1.1'
env.roledefs,定義角色分組,比如web組與db組主機(jī)區(qū)分開(kāi)來(lái),定義如下:
env.roledefs = {
'webservers':['192.168.1.21','192.168.1.22','192.168.1.23'],
'dbservers':['192.168.1.24','192.168.1.25'],
}
引用時(shí)使用python修飾符的形式進(jìn)行,角色修飾符下面的任務(wù)函數(shù)為其作用域,下面來(lái)看一個(gè)示例:
@roles('webservers') def webtask(): run('/etc/init.d/nginx start') @roles('dbservers'): def dbtask(): run('/etc/init.d/mysql start') @roles('webservers','dbservers') def publictask(): run('uptime') def deploy(): execute(webtask) execute(dbtask) execute(publictask)
在命令執(zhí)行fab deploy就可以實(shí)現(xiàn)不同角色執(zhí)行不同的任務(wù)函數(shù)。
常用API
Fabric提供了一組簡(jiǎn)單但功能強(qiáng)大的fabric.api命令集,簡(jiǎn)單地調(diào)用這樣API就能完成大部分應(yīng)用場(chǎng)景需求,F(xiàn)abric支持常用的方法及說(shuō)明如下:
local,執(zhí)行本地命令,如local:('uname -s');
lcd,切換本地目錄,如lcd:('/home');
cd,切換遠(yuǎn)程目錄,如cd:('/data/logs/');
run,執(zhí)行遠(yuǎn)程命令,如:run('free -m')
sudo,sudo方式執(zhí)行遠(yuǎn)程命令,如:sudo('/etc/init.d/httpd start');
put,上傳本地文件到遠(yuǎn)程主機(jī),如:put('/home/user.info','/data/user.info');
get,從遠(yuǎn)程主機(jī)下載文件到本地,如:get('/home/user.info','/data/user.info');
prompt,獲得用戶輸入信息,如:prompt('please input user password:');
confirm,獲得提示信息確認(rèn),如:confirm('Test failed,Continue[Y/N]');
reboot,重啟遠(yuǎn)程主機(jī),如reboot();
@task,函數(shù)修飾符,標(biāo)識(shí)符的函數(shù)為fab可調(diào)用,非標(biāo)記對(duì)fab不可見(jiàn),純業(yè)務(wù)邏輯;
@runs_once,函數(shù)修飾符,標(biāo)識(shí)符的函數(shù)只會(huì)執(zhí)行一次,不受多臺(tái)主機(jī)影響;
示例1:查看本地與遠(yuǎn)程主機(jī)信息
本示例調(diào)用local()方法執(zhí)行本地命令,添加"@runs_once"修飾保證該任務(wù)函數(shù)只執(zhí)行一次。調(diào)用run()方法執(zhí)行遠(yuǎn)程命令,
#!/usr/bin/env python # -*- coding: utf-8 -*- from fabric.api import * env.user = 'root' env.hosts = ['192.168.1.43','192.168.1.23','192.168.1.24'] env.port = '22' env.password = '123456' @runs_once #查看本地系統(tǒng)信息,當(dāng)有多臺(tái)主機(jī)時(shí)只運(yùn)行一次 def local_task(): #本地任務(wù)函數(shù) local('uname -a') def remote_task(): with cd('/data'): #with的作用是讓后面的表達(dá)式語(yǔ)句繼承當(dāng)前狀態(tài),實(shí)現(xiàn)cd /var && ls -l的效果 run('ls -l')
通過(guò)fab命令分別調(diào)用local_task任務(wù)函數(shù)運(yùn)行效果如下圖所示
結(jié)果中顯示了[192.168.1.23] Executing task 'local_task',但事實(shí)上并非在主機(jī)192.168.1.23上執(zhí)行任務(wù),而是返回Fabric主機(jī)本地的'uname -a'的執(zhí)行效果
調(diào)用remtoe_task任務(wù)函數(shù)的執(zhí)行結(jié)果如下圖所示
示例2;動(dòng)態(tài)獲取遠(yuǎn)程目錄列表
本示例使用"@task"修飾符標(biāo)志入口函數(shù)go()對(duì)外部可以,配合"@runs_once"符等待接受用戶輸入,最后調(diào)用worktask()任務(wù)函數(shù)實(shí)現(xiàn)遠(yuǎn)程命令執(zhí)行,
#!/usr/bin/env python # -*- coding: utf-8 -*- from fabric.api import * env.user = 'root' env.hosts = ['192.168.1.23','192.168.1.24'] env.password = '123456' @runs_once #在主機(jī)遍歷過(guò)程中,只有一臺(tái)出發(fā)此函數(shù) def input_raw(): return prompt("please input direcotry name:",default="/home") def worktask(dirname): run("ls -l %s" %dirname) @task def go(): getdirname = input_raw() worktask(getdirname)
該示例實(shí)現(xiàn)了一個(gè)動(dòng)態(tài)輸入遠(yuǎn)程目錄名稱,在獲取目錄列表的功能,由于我們只要求輸入一次,再顯示所有主機(jī)上該目錄的列表信息,調(diào)用了一個(gè)子函數(shù)input_raw(同時(shí)配置)@runs_once修飾符來(lái)達(dá)到此目的,執(zhí)行結(jié)果如下圖
文件上傳與執(zhí)行
#!/usr/bin/env python # -*- coding: utf-8 -*- from fabric.api import * from fabric.context_managers import * from fabric.contrib.console import confirm env.hosts=['192.168.1.23','192.168.1.24'] #假如所有主機(jī)密碼都不一樣,可以通過(guò)env.passwords字典變量一一指定 env.passwords = { 'root@192.168.1.23:22': '123456', 'root@192.168.1.24:22': '123456', } lpackpath="/home/a.tar.gz" rpackpath="/tmp/install" @task def put_task(): run("mkdir -p /tmp/install") with settings(warn_only=True): result = put(lpackpath, rpackpath) if result.failed and not confirm("put file failed, Continue[Y/N]?"): abort("Aborting file put task!") @task def run_task(): with cd("/tmp/install"): run("tar -zxvf a.tar.gz") @task def go(): put_task() run_task()
- python fabric實(shí)現(xiàn)遠(yuǎn)程操作和部署示例
- Python的批量遠(yuǎn)程管理和部署工具Fabric用法實(shí)例
- Python下Fabric的簡(jiǎn)單部署方法
- python fabric使用筆記
- Python的自動(dòng)化部署模塊Fabric的安裝及使用指南
- Python自動(dòng)化部署工具Fabric的簡(jiǎn)單上手指南
- Python自動(dòng)化運(yùn)維和部署項(xiàng)目工具Fabric使用實(shí)例
- Fabric 應(yīng)用案例
- 關(guān)于Centos安裝fabric遇到的問(wèn)題和解決方法
- 如何利用Fabric自動(dòng)化你的任務(wù)
相關(guān)文章
MongoDB學(xué)習(xí)筆記(六) MongoDB索引用法和效率分析
MongoDB中的索引其實(shí)類似于關(guān)系型數(shù)據(jù)庫(kù),都是為了提高查詢和排序的效率的,并且實(shí)現(xiàn)原理也基本一致2013-07-07無(wú)盤(pán)完美解決Windows Server 2012或2016無(wú)法安裝.NET Framework3.5的方法
今天小編就為大家分享一篇關(guān)于無(wú)盤(pán)完美解決Windows Server 2012或2016無(wú)法安裝.NET Framework3.5的方法,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03windows服務(wù)器如何創(chuàng)建.開(kāi)頭(.well-known)的文件夾
國(guó)內(nèi)的云服務(wù)商騰訊云提供免費(fèi)有效期一年的SSL證書(shū),申請(qǐng)過(guò)程中需要身份驗(yàn)證,需要dns域名解析或者服務(wù)器文件驗(yàn)證。如果想使用文件驗(yàn)證,必須創(chuàng)建一個(gè)以.開(kāi)頭的文件,使用windows服務(wù)器如何創(chuàng)建.開(kāi)頭的文件夾。2023-04-04服務(wù)器錯(cuò)誤碼500 501 502 503 504 505 詳解
這篇文章主要介紹了服務(wù)器錯(cuò)誤碼500 501 502 503 504 505 詳解,需要的朋友可以參考下2015-07-07阿里云服務(wù)器購(gòu)買(mǎi)搭建過(guò)程的方法步驟
這篇文章主要介紹了阿里云服務(wù)器購(gòu)買(mǎi)搭建過(guò)程的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03windows+apache+mod_python配置django運(yùn)行環(huán)境
環(huán)境:windows2008, apache2.2, python2.5, mod_python-3.3.1.win32-py2.5-Apache2.2, django-1.0.2_final2012-06-06MongoDB學(xué)習(xí)筆記(一) MongoDB介紹與安裝方法
最近開(kāi)始學(xué)習(xí)非關(guān)系型數(shù)據(jù)庫(kù)MongoDB,卻在博客園上找不到比較系統(tǒng)的教程,很多資料都要去查閱英文網(wǎng)站,效率比較低下。本人不才,借著自學(xué)的機(jī)會(huì)把心得體會(huì)都記錄下來(lái),方便感興趣的童鞋分享討論2013-07-07