uname
命令是查看系統(tǒng)的發(fā)行版。
可以寫這樣一個Fabric腳本:
from fabric.api import run def host_type(): run('uname -s')
將上面的腳本保存為fabfile.py,就可以通過fab
命令在多個主機(jī)上執(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í)行,因?yàn)槟氵€沒有安裝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ù),其功能是在遠(yuǎn)端主機(jī)上執(zhí)行命令。fabric.api中還提供了local函數(shù),用于執(zhí)行本地(Fabric所在的主機(jī))命令。
如下:
from fabric.api import local def lslocal(): local('ls')
類似遠(yuǎn)端命令和本地命令,F(xiàn)abric也區(qū)分遠(yuǎn)端目錄和本地目錄。Fabric提供的對遠(yuǎn)端和本地目錄的操作分別是cd和lcd。如果你用過命令行的ftp,這很容易理解。
讓我們看一個例子:
def filepath(): remote_dir = '/opt/xxx' with cd(remote_dir): run("touch README")
上面代碼的功能是進(jìn)入遠(yuǎn)端的/opt/xxx目錄,并創(chuàng)建一個README文件。
Fabric還提供了很多的命令,比如文件操作等。
管理服務(wù)器連接
前面的例子中,都需要在fab命令行參數(shù)中指定server。當(dāng)要管理大量服務(wù)器時很麻煩。Fabric提供了環(huán)境變量的字典env,其中就包含了hosts字典項(xiàng),可以定義需要連接的server。
如下:
from fabric.api import env, run env.hosts = ['host1', 'host2'] def mytask(): run('ls /var/www')
也可以為每個任務(wù)單獨(dú)指定要執(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ù),F(xiàn)abric中還定義了Role,有興趣可以閱讀其官方文檔。
管理SSH密碼、用戶、端口
盡管更推薦使用SSH公鑰認(rèn)證,但是Fabric還是提供了管理密碼的機(jī)制。Fabric提供了兩層密碼。
如果你的server有相同的密碼,可以在env.password
中設(shè)置默認(rèn)的密碼;如果server密碼不同,還可以在env.passwords
中設(shè)置(host,password)對,為每個server設(shè)置單獨(dú)的ssh密碼。
上面的host字符串采用這種格式:username@hostname:port。所以,在指定ssh密碼的同時,也就指定了ssh用戶。同密碼一樣,你也可以在env.user
中指定一個默認(rèn)的用戶。如果都沒有指定,執(zhí)行fab
命令時會提示你輸入密碼。
使用Fabric,你可以管理一系列host的SSH連接(包括主機(jī)名,用戶,密碼),定義一系列的任務(wù)函數(shù),然后靈活的指定在哪些host上執(zhí)行哪些任務(wù)。這非常使用于需要管理大量host的場景,比如運(yùn)維,私有云管理,應(yīng)用自動化部署等。
總結(jié)
本文只是一篇入門文檔,遠(yuǎn)沒有體現(xiàn)出Fabric的強(qiáng)大。實(shí)際上,F(xiàn)abric還包括大量的功能,比如Role的定義,遠(yuǎn)程交互及異常處理,并發(fā)執(zhí)行,文件操作等,并且不僅僅局限于命令行方式,可以在你的應(yīng)用中調(diào)用Fabric。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com