日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

遠(yuǎn)程部署工具Fabric詳解(支持Python3)

系統(tǒng) 2184 0

前言

如果你搜一圈 "Fabric "關(guān)鍵字,你會發(fā)現(xiàn) 90% 的資料都是過時的,因為現(xiàn)在 Fabric 支持 Python3,但是它又不兼容舊版 Fabric。所以,如果你按照那些教程去操作的話根本跑不通。

如果你還沒用過 Fabric,那么這篇文章就是幫你快速上手 Fabric 的。不管你現(xiàn)在用不用,先了解了以后也用得著。

平時我們的開發(fā)流程是這樣,經(jīng)過幾個月奮戰(zhàn),項目終于開發(fā)完了,測試也沒問題了,我們就把代碼提交到 GitHub 那樣的托管平臺,準(zhǔn)備部署到正式環(huán)境。你小心翼翼地登錄到正式服務(wù)器,進(jìn)入到項目目錄中,把代碼從遠(yuǎn)程倉庫拉下來,然后啟動程序。后面每次有新功能發(fā)布或者哪怕只是修改了一個小小的 Bug 時,你都要執(zhí)行重復(fù)的操作,登錄服務(wù)器,切換到指定目錄,拉取代碼,重啟服務(wù)。

其實這種操作非常繁瑣,也沒什么技術(shù)含量,還容易出問題,于是 Fabric 出場了。Fabric 是一個遠(yuǎn)程部署神器,它可以在本地執(zhí)行遠(yuǎn)程服務(wù)器的命令。

怎么做?很簡單,就幾個步驟。

安裝 Fabric

            
$ pip install fabric --upgrade
          

注意,如果你安裝的是舊版的 Fabric,那么新版的 Fabric 是不兼容舊版的,目前 Fabric 有三個版本,F(xiàn)abric1 就是以前的 Fabric,只支持 Python2,已不推薦使用,而 Fabric2 就是現(xiàn)在的 Fabric,同時支持 Python2 和 Python3, 也是官方強(qiáng)烈推薦的版本, 還有一個 Fabric3,這是網(wǎng)友從舊版的 Fabric1 克隆過來的非官方版本,但是兼容 Fabric1,也支持 Python2 和 Python3。

最新的 Fabric 不需要 fabfile.py 文件, 也不需要 fab 命令,而現(xiàn)在網(wǎng)絡(luò)上幾乎所有的教程、資料都還是基于 fabric1 寫的,當(dāng)你在看那些教程的時候,注意甄別。 而新版 Fabric 提供的 API 非常簡單。

運行命令

先看個例子,下面是一段部署腳本

            
# deploy.py
# 1. 創(chuàng)建一個遠(yuǎn)程連接
# 2. 進(jìn)入指定目錄
# 3. 在指定目錄下面執(zhí)行重啟命令

from fabric import Connection

def main():
  # ip 我是隨便填的
  # 如果你的電腦配了ssh免密碼登錄,就不需要 connect_kwargs 來指定密碼了。
  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)境敲錯命令刪數(shù)據(jù)庫跑路了。

Fabric 不僅支持 Linux,而且在 Windows 平臺也能很好的運行,在中小型項目,它是非常不錯的運維工具,有了 Frabic ,管理上百臺服務(wù)器都不成問題。

構(gòu)建連接

            
class Connection(Context):
  host = None
  user = None
  port = None
  ssh_config = None
  connect_timeout = None
  connect_kwargs = None
  ...
          

構(gòu)建 Connection 對象的方式有不同的方式,例如你可以將 host 寫成 "root@192.168.101.1:22" ,也可以作為3個參數(shù)分開寫。而 connect_kwargs 是字典對象,通常填服務(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')
          

多臺服務(wù)器

如果是要在多臺服務(wù)器運行命令,簡單的辦法就是使用迭代,挨個服務(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ù)說明:

  • *hosts: 可以傳入多個主機(jī)名或IP
  • **kwargs 接收的參數(shù)可以和Connection一樣,可以指定密碼

本文完,你 get 了嗎?

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 广南县| 焉耆| 宝鸡市| 特克斯县| 公安县| 泸定县| 青岛市| 莱芜市| 贺兰县| 隆回县| 延边| 新蔡县| 青田县| 碌曲县| 保康县| 涿州市| 浠水县| 溧阳市| 古浪县| 新干县| 潼关县| 西乌珠穆沁旗| 洛川县| 民乐县| 旅游| 睢宁县| 孟津县| 连州市| 洛川县| 琼结县| 昭通市| 西乡县| 辛集市| 清河县| 府谷县| 溧阳市| 阿图什市| 常山县| 秦安县| 连州市| 台湾省|