使用Fabric自动化你的任务
Fabric是一個(gè)Python庫,可以通過SSH在多個(gè)host上批量執(zhí)行任務(wù)。你可以編寫任務(wù)腳本,然后通過Fabric在本地就可以使用SSH在大量遠(yuǎn)程服務(wù)器上自動(dòng)運(yùn)行。這些功能非常適合應(yīng)用的自動(dòng)化部署,或者執(zhí)行系統(tǒng)管理任務(wù)。
讓我們首先看一個(gè)例子。我們知道在*NIX下面,uname命令是查看系統(tǒng)的發(fā)行版。可以寫這樣一個(gè)Fabric腳本:
def host_type():
run('uname -s')
將上面的腳本保存為fabfile.py,就可以通過fab命令在多個(gè)主機(jī)上執(zhí)行host_type腳本了:
$ fab -H localhost,linuxbox host_type
[localhost] run: uname -s
[localhost] out: Darwin
[linuxbox] run: uname -s
[linuxbox] out: Linux
執(zhí)行過程中可能需要你輸入系統(tǒng)密碼。
安裝
如果你看到這里了,說明你開始對Fabric感興趣了。但是上述操作在你那里無法執(zhí)行,因?yàn)槟氵€沒有安裝Fabric。安裝Fabric很簡單,可以用pip或者easy_install,也可以下載原代碼安裝。
任務(wù)函數(shù)
很好,安裝Fabric并沒有難住你。可能你已經(jīng)成功的執(zhí)行了前面的任務(wù),現(xiàn)在讓我們更深入一些。
Fabric中的任務(wù)就是一個(gè)python函數(shù),姑且讓我們稱之為“任務(wù)函數(shù)”。既然是python函數(shù),那么對函數(shù)的一些用法也適用于任務(wù)函數(shù)。比如傳遞參數(shù)、互相調(diào)用、返回值等等。首先看一個(gè)傳遞參數(shù)的例子:
def hello(name="world"):print("Hello %s!" % name)
在執(zhí)行任務(wù)的時(shí)候,可以通過fab的命令行參數(shù)為任務(wù)函數(shù)傳遞參數(shù):
$ fab hello:name=Holbrook
Hello Holbrook!
組合任務(wù)的例子如下:
def host_type():
run('uname -s')
def hello(name="world"):
print("Hello %s!" % name)
def composite(name="world"):
hello(name)
host_type()
Fabric提供的命令
前面我們見過了fabric.api模塊中的run函數(shù),其功能是在遠(yuǎn)端主機(jī)上執(zhí)行命令。fabric.api中還提供了local函數(shù),用于執(zhí)行本地(Fabric所在的主機(jī))命令。如下:
from fabric.api import localdef lslocal():
local('ls')
類似遠(yuǎn)端命令和本地命令,Fabric也區(qū)分遠(yuǎn)端目錄和本地目錄。Fabric提供的對遠(yuǎn)端和本地目錄的操作分別是cd和lcd。如果你用過命令行的ftp,這很容易理解。讓我們看一個(gè)例子:
def filepath():remote_dir = '/opt/xxx'
with cd(remote_dir):
run("touch README")
上面代碼的功能是進(jìn)入遠(yuǎn)端的/opt/xxx目錄,并創(chuàng)建一個(gè)README文件。
Fabric還提供了很多的命令,比如文件操作等,可以參考Fabric的operations模塊。
管理服務(wù)器連接
前面的例子中,都需要在fab命令行參數(shù)中指定server。當(dāng)要管理大量服務(wù)器時(shí)很麻煩。Fabric提供了環(huán)境變量的字典env,其中就包含了hosts字典項(xiàng),可以定義需要連接的server。如下:
from fabric.api import env, runenv.hosts = ['host1', 'host2']
def mytask():
run('ls /var/www')
也可以為每個(gè)任務(wù)單獨(dú)指定要執(zhí)行該任務(wù)的host列表:
from fabric.api import env, rundef set_hosts():
env.hosts = ['host1', 'host2']
def mytask():
run('ls /var/www')
這樣執(zhí)行 fab set_hosts mytask時(shí),就可以為set_hosts中指定的兩個(gè)host執(zhí)行mytask任務(wù)了。如果你懶得寫函數(shù),在fab命令行中指定也是一樣的:
fab mytask:hosts="host1;host2"
為了更方便的執(zhí)行批量任務(wù),Fabric中還定義了Role,有興趣可以閱讀其官方文檔。
管理SSH密碼、用戶、端口
盡管更推薦使用SSH公鑰認(rèn)證,但是Fabric還是提供了管理密碼的機(jī)制。Fabric提供了兩層密碼。
如果你的server有相同的密碼,可以在env.password中設(shè)置默認(rèn)的密碼;如果server密碼不同,還可以在env.passwords中設(shè)置(host,password)對,為每個(gè)server設(shè)置單獨(dú)的ssh密碼。
上面的host字符串采用這種格式:username@hostname:port。所以,在指定ssh密碼的同時(shí),也就指定了ssh用戶。同密碼一樣,你也可以在env.user中指定一個(gè)默認(rèn)的用戶。如果都沒有指定,執(zhí)行fab命令時(shí)會(huì)提示你輸入密碼。
小結(jié)
使用Fabric,你可以管理一系列host的SSH連接(包括主機(jī)名,用戶,密碼),定義一系列的任務(wù)函數(shù),然后靈活的指定在哪些host上執(zhí)行哪些任務(wù)。這非常使用于需要管理大量host的場景,比如運(yùn)維,私有云管理,應(yīng)用自動(dòng)化部署等。
本文只是一篇入門文檔,遠(yuǎn)沒有體現(xiàn)出Fabric的強(qiáng)大。實(shí)際上,Fabric還包括大量的功能,比如Role的定義,遠(yuǎn)程交互及異常處理,并發(fā)執(zhí)行,文件操作等,并且不僅僅局限于命令行方式,可以在你的應(yīng)用中調(diào)用Fabric。
希望本文能夠引起你對Fabric的興趣,并在你的實(shí)際應(yīng)用中解決問題。
轉(zhuǎn)載于:https://www.cnblogs.com/sideny/p/3388283.html
總結(jié)
以上是生活随笔為你收集整理的使用Fabric自动化你的任务的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java接口和Java抽象类的认识
- 下一篇: Logistic Regression