使用Fabric自動化你的任務


fabric是什么?

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

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

將上面的腳本保存為fabfile.py,就可以通過fab命令在多個主機上執行host_type腳本了:
$ fab -H localhost,linuxbox host_type
[localhost] run: uname -s
[localhost] out: Darwin
[linuxbox] run: uname -s
[linuxbox] out: Linux

執行過程中可能需要你輸入系統密碼。

安裝

如果你看到這里了,說明你開始對Fabric感興趣了。但是上述操作在你那里無法執行,因為你還沒有安裝Fabric。安裝Fabric很簡單,可以用pip或者easy_install,也可以下載原代碼安裝。

任務函數

很好,安裝Fabric並沒有難住你。可能你已經成功的執行了前面的任務,現在讓我們更深入一些。

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

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

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

組合任務的例子如下:

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

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

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

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

上面代碼的功能是進入遠端的/opt/xxx目錄,並創建一個README文件。

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

管理服務器連接

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

from fabric.api import env, run

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

也可以為每個任務單獨指定要執行該任務的host列表:

from fabric.api import env, run

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

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

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

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

管理SSH密碼、用戶、端口

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

小結

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM