如何利用Fabric自動化你的任務

WBOY
發布: 2016-12-05 13:27:12
原創
1024 人瀏覽過

首先讓我們先來看一個例子。我們知道在*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很簡單,可以用pipeasy_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也提供了很多的命令,例如文件操作等。

管理伺服器連線

前面的例子中,都需要在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的興趣,並在你的實際應用中解決問題。如果有疑問大家可以留言交流。

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板