首先讓我們首先看一個例子。我們知道在*NIX下面,uname命令是查看系統的發行版。
可以寫這樣一個Fabric腳本:
from fabric.api import rundef 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=HolbrookHello Holbrook!
組合任務的例子如下:
from fabric.api import rundef 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 localdef 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, runenv.hosts = ['host1', 'host2']def mytask(): run('ls /var/www')也可以為每個任務單獨指定要執行該任務的host列表:
from fabric.api import env, rundef 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的興趣,并在你的實際應用中解決問題。如果有疑問大家可以留言交流。
新聞熱點
疑難解答