99热99这里只有精品6国产,亚洲中文字幕在线天天更新,在线观看亚洲精品国产福利片 ,久久久久综合网

歡迎加入QQ討論群258996829
麥子學(xué)院 頭像
蘋果6袋
6
麥子學(xué)院

使用Fabric自動化你的任務(wù)入門篇

發(fā)布時間:2016-08-27 00:04  回復(fù):0  查看:2775   最后回復(fù):2016-08-27 00:04  

使用Fabric可以自動化我們的任務(wù)。想要提高我們的工作效率,學(xué)習(xí)Fabric變得很必要,這里就帶大家入門Fabric。

 

fabric是什么?

Fabric是一個Python庫,可以通過SSH在多個host上批量執(zhí)行任務(wù)。你可以編寫任務(wù)腳本,然后通過Fabric在本地就可以使用SSH在大量遠程服務(wù)器上自動運行。這些功能非常適合應(yīng)用的自動化部署,或者執(zhí)行系統(tǒng)管理任務(wù)。
讓我們首先看一個例子。我們知道在*NIX下面,uname命令是查看系統(tǒng)的發(fā)行版??梢詫戇@樣一個Fabric腳本:

from fabric.api import run
def host_type():
    run('uname -s')

將上面的腳本保存為fabfile.py,就可以通過fab命令在多個主機上執(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í)行,因為你還沒有安裝Fabric。安裝Fabric很簡單,可以用pip或者easy_install,也可以下載原代碼安裝。

 

任務(wù)函數(shù)

很好,安裝Fabric并沒有難住你??赡苣阋呀?jīng)成功的執(zhí)行了前面的任務(wù),現(xiàn)在讓我們更深入一些。

Fabric中的任務(wù)就是一個python函數(shù),姑且讓我們稱之為任務(wù)函數(shù)。既然是python函數(shù),那么對函數(shù)的一些用法也適用于任務(wù)函數(shù)。比如傳遞參數(shù)、互相調(diào)用、返回值等等。首先看一個傳遞參數(shù)的例子:

def hello(name="world"):
    print("Hello %s!" % name)

在執(zhí)行任務(wù)的時候,可以通過fab的命令行參數(shù)為任務(wù)函數(shù)傳遞參數(shù):
$ fab hello:name=Holbrook
Hello Holbrook!

組合任務(wù)的例子如下:

from fabric.api import run
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ù),其功能是在遠端主機上執(zhí)行命令。fabric.api中還提供了local函數(shù),用于執(zhí)行本地(Fabric所在的主機)命令。如下:

from fabric.api import local
def lslocal():
    local('ls')

類似遠端命令和本地命令,Fabric也區(qū)分遠端目錄和本地目錄。Fabric提供的對遠端和本地目錄的操作分別是cdlcd。如果你用過命令行的ftp,這很容易理解。讓我們看一個例子:

def filepath():
    remote_dir = '/opt/xxx'
    with cd(remote_dir):
        run("touch README")

上面代碼的功能是進入遠端的/opt/xxx目錄,并創(chuàng)建一個README文件。

Fabric還提供了很多的命令,比如文件操作等,可以參考Fabricoperations模塊。

 

管理服務(wù)器連接

前面的例子中,都需要在fab命令行參數(shù)中指定server。當(dāng)要管理大量服務(wù)器時很麻煩。Fabric提供了環(huán)境變量的字典env,其中就包含了hosts字典項,可以定義需要連接的server。如下:

from fabric.api import env, run

env.hosts = ['host1', 'host2']
def mytask():
    run('ls /var/www')

也可以為每個任務(wù)單獨指定要執(zhí)行該任務(wù)的host列表:

 

from fabric.api import env, run

def set_hosts():
    env.hosts = ['host1', 'host2']

def mytask():
    run('ls /var/www')

 

這樣執(zhí)行 fab set_hosts mytask時,就可以為set_hosts中指定的兩個host執(zhí)行mytask任務(wù)了。如果你懶得寫函數(shù),在fab命令行中指定也是一樣的:
fab mytask:hosts="host1;host2"

為了更方便的執(zhí)行批量任務(wù),Fabric中還定義了Role,有興趣可以閱讀其官方文檔。

 

管理SSH密碼、用戶、端口

盡管更推薦使用SSH公鑰認證,但是Fabric還是提供了管理密碼的機制。Fabric提供了兩層密碼。
如果你的server有相同的密碼,可以在env.password中設(shè)置默認的密碼;如果server密碼不同,還可以在env.passwords中設(shè)置(host,password)對,為每個server設(shè)置單獨的ssh密碼。
上面的host字符串采用這種格式:username@hostname:port。所以,在指定ssh密碼的同時,也就指定了ssh用戶。同密碼一樣,你也可以在env.user中指定一個默認的用戶。如果都沒有指定,執(zhí)行fab命令時會提示你輸入密碼。

 

小結(jié)

使用Fabric,你可以管理一系列hostSSH連接(包括主機名,用戶,密碼),定義一系列的任務(wù)函數(shù),然后靈活的指定在哪些host上執(zhí)行哪些任務(wù)。這非常使用于需要管理大量host的場景,比如運維,私有云管理,應(yīng)用自動化部署等。
本文只是一篇入門文檔,遠沒有體現(xiàn)出Fabric的強大。實際上,Fabric還包括大量的功能,比如Role的定義,遠程交互及異常處理,并發(fā)執(zhí)行,文件操作等,并且不僅僅局限于命令行方式,可以在你的應(yīng)用中調(diào)用Fabric。
希望本文能夠引起你對Fabric的興趣,并在你的實際應(yīng)用中解決問題。

 

 

文章來自:博客園/心內(nèi)求法

您還未登錄,請先登錄

熱門帖子

最新帖子

?