最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

如何利用Fabric自動化你的任務(wù)

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 14:27:38
文檔

如何利用Fabric自動化你的任務(wù)

如何利用Fabric自動化你的任務(wù):首先讓我們首先看一個例子。我們知道在*NIX下面,uname命令是查看系統(tǒng)的發(fā)行版。 可以寫這樣一個Fabric腳本: from fabric.api import run def host_type(): run('uname -s') 將上面的腳本保存為fabfile.py,就可以通過fab命令在多個主機(jī)
推薦度:
導(dǎo)讀如何利用Fabric自動化你的任務(wù):首先讓我們首先看一個例子。我們知道在*NIX下面,uname命令是查看系統(tǒng)的發(fā)行版。 可以寫這樣一個Fabric腳本: from fabric.api import run def host_type(): run('uname -s') 將上面的腳本保存為fabfile.py,就可以通過fab命令在多個主機(jī)

首先讓我們首先看一個例子。我們知道在*NIX下面,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

文檔

如何利用Fabric自動化你的任務(wù)

如何利用Fabric自動化你的任務(wù):首先讓我們首先看一個例子。我們知道在*NIX下面,uname命令是查看系統(tǒng)的發(fā)行版。 可以寫這樣一個Fabric腳本: from fabric.api import run def host_type(): run('uname -s') 將上面的腳本保存為fabfile.py,就可以通過fab命令在多個主機(jī)
推薦度:
標(biāo)簽: 自動 如何 任務(wù)
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top