這篇文章將為大家詳細(xì)講解有關(guān)如何安裝遠(yuǎn)程部署工具Fabric,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)不只是一家網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司;我們對(duì)營(yíng)銷、技術(shù)、服務(wù)都有自己獨(dú)特見(jiàn)解,公司采取“創(chuàng)意+綜合+營(yíng)銷”一體化的方式為您提供更專業(yè)的服務(wù)!我們經(jīng)歷的每一步也許不一定是最完美的,但每一步都有值得深思的意義。我們珍視每一份信任,關(guān)注我們的成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)質(zhì)量和服務(wù)品質(zhì),在得到用戶滿意的同時(shí),也能得到同行業(yè)的專業(yè)認(rèn)可,能夠?yàn)樾袠I(yè)創(chuàng)新發(fā)展助力。未來(lái)將繼續(xù)專注于技術(shù)創(chuàng)新,服務(wù)升級(jí),滿足企業(yè)一站式營(yíng)銷型網(wǎng)站需求,讓再小的成都品牌網(wǎng)站建設(shè)也能產(chǎn)生價(jià)值!安裝 Fabric
$ pip install fabric --upgrade
注意,如果你安裝的是舊版的 Fabric,那么新版的 Fabric 是不兼容舊版的,目前 Fabric 有三個(gè)版本,F(xiàn)abric1 就是以前的 Fabric,只支持 Python2,已不推薦使用,而 Fabric2 就是現(xiàn)在的 Fabric,同時(shí)支持 Python2 和 Python3, 也是官方強(qiáng)烈推薦的版本, 還有一個(gè) Fabric3,這是網(wǎng)友從舊版的 Fabric1 克隆過(guò)來(lái)的非官方版本,但是兼容 Fabric1,也支持 Python2 和 Python3。
最新的 Fabric 不需要 fabfile.py 文件, 也不需要 fab 命令,而現(xiàn)在網(wǎng)絡(luò)上幾乎所有的教程、資料都還是基于 fabric1 寫(xiě)的,當(dāng)你在看那些教程的時(shí)候,注意甄別。 而新版 Fabric 提供的 API 非常簡(jiǎn)單。
運(yùn)行命令
先看個(gè)例子,下面是一段部署腳本
# deploy.py # 1. 創(chuàng)建一個(gè)遠(yuǎn)程連接 # 2. 進(jìn)入指定目錄 # 3. 在指定目錄下面執(zhí)行重啟命令 from fabric import Connection def main(): # ip 我是隨便填的 # 如果你的電腦配了ssh免密碼登錄,就不需要 connect_kwargs 來(lái)指定密碼了。 c = Connection("root@232.231.231.22", connect_kwargs={"password": "youpassword"}) with c.cd('/var/www/youproject'): c.run("git pull origin master") c.run("/usr/bin/supervisorctl -c ../supervisor/supervisord.conf restart youproject") if __name__ == '__main__': main()
執(zhí)行
python deploy.py
執(zhí)行完成后,最新代碼就已經(jīng)部署到正式環(huán)境并重啟了服務(wù),是不是非常方便,媽媽再也不要擔(dān)心我在正式環(huán)境敲錯(cuò)命令刪數(shù)據(jù)庫(kù)跑路了。
Fabric 不僅支持 Linux,而且在 Windows 平臺(tái)也能很好的運(yùn)行,在中小型項(xiàng)目,它是非常不錯(cuò)的運(yùn)維工具,有了 Frabic ,管理上百臺(tái)服務(wù)器都不成問(wèn)題。
構(gòu)建連接
class Connection(Context): host = None user = None port = None ssh_config = None connect_timeout = None connect_kwargs = None ...
構(gòu)建 Connection 對(duì)象的方式有不同的方式,例如你可以將 host 寫(xiě)成 "root@192.168.101.1:22" ,也可以作為3個(gè)參數(shù)分開(kāi)寫(xiě)。而 connect_kwargs 是字典對(duì)象,通常填服務(wù)器的登錄密碼或者密鑰。
上傳文件
run 方法用于執(zhí)行命令,cd 進(jìn)入指定目錄,put 方法用于上傳文件, 例如:
from fabric import Connection c = Connection('web1') c.put('myfiles.tgz', '/opt/mydata') c.run('tar -C /opt/mydata -xzvf /opt/mydata/myfiles.tgz')
多臺(tái)服務(wù)器
如果是要在多臺(tái)服務(wù)器運(yùn)行命令,簡(jiǎn)單的辦法就是使用迭代,挨個(gè)服務(wù)器執(zhí)行命令:
# web1,web2,mac1 都是服務(wù)器的名字,你也可以用ip代替 >>> from fabric import Connection >>> for host in ('web1', 'web2', 'mac1'): >>> result = Connection(host).run('uname -s') ... print("{}: {}".format(host, result.stdout.strip())) ... web1: Linux web2: Linux mac1: Darwin
或者使用 SerialGroup
from fabric import SerialGroup as Group pool = Group('web1', 'web2', 'web3', connect_kwargs={"password": "youpassword"} ) pool.put('myfiles.tgz', '/opt/mydata') pool.run('tar -C /opt/mydata -xzvf /opt/mydata/myfiles.tgz')
Group(*hosts, **kwargs) 參數(shù)說(shuō)明:
*hosts: 可以傳入多個(gè)主機(jī)名或IP
**kwargs 接收的參數(shù)可以和Connection一樣,可以指定密碼
關(guān)于“如何安裝遠(yuǎn)程部署工具Fabric”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。