使用Fabric自動化你的任務,fabric自動化任務

來源:互聯網
上載者:User

使用Fabric自動化你的任務,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的興趣,並在你的實際應用中解決問題。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.