項目輕量級部署神器:Fabric

若是你搜一圈 "Fabric "關鍵字,你會發現 90% 的資料都是過期的,由於如今 Fabric 支持 Python3,可是它又不兼容舊版 Fabric。因此,若是你按照那些教程去操做的話根本跑不通。而這篇文章是給使用Python3的同窗準備的。html

若是你還沒用過 Fabric,那麼這篇文章就是幫你快速上手 Fabric 的,無論你如今用不用,先了解了之後也用得着。python

平時咱們的開發流程是這樣,通過幾個月奮戰,項目終於開發完了,測試也沒問題了,咱們就把代碼提交到 GitHub 那樣的託管平臺,準備部署到正式環境。你當心翼翼地登陸到正式服務器,進入到項目目錄中,把代碼從遠程倉庫拉下來,而後啓動程序。後面每次有新功能發佈或者哪怕只是修改了一個小小的 Bug 時,你都要執行重複的操做,登陸服務器,切換到指定目錄,拉取代碼,重啓服務。git

其實這種操做很是繁瑣,也沒什麼技術含量,還容易出問題,因而 Fabric 出場了。Fabric 是一個遠程部署神器,它能夠在本地執行遠程服務器的命令。web

怎麼作?很簡單,就幾個步驟。數據庫

安裝 Fabric

$ pip install fabric --upgrade
複製代碼

注意,若是你安裝的是舊版的 Fabric,那麼新版的 Fabric 是不兼容舊版的,目前 Fabric 有三個版本,Fabric1 就是之前的 Fabric,只支持 Python2,已不推薦使用,而 Fabric2 就是如今的 Fabric,同時支持 Python2 和 Python3, 也是官方強烈推薦的版本, 還有一個 Fabric3,這是網友從舊版的 Fabric1 克隆過來的非官方版本,可是兼容 Fabric1,也支持 Python2 和 Python3。bash

最新的 Fabric 不須要 fabfile.py 文件, 也不須要 fab 命令,而如今網絡上幾乎全部的教程、資料都仍是基於 fabric1 寫的,當你在看那些教程的時候,注意甄別。 而新版 Fabric 提供的 API 很是簡單。服務器

運行命令

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

# deploy.py
# 1. 建立一個遠程鏈接
# 2. 進入指定目錄
# 3. 在指定目錄下面執行重啓命令

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()
複製代碼

執行運維

python deploy.py
複製代碼

執行完成後,最新代碼就已經部署到正式環境並重啓了服務,是否是很是方便,媽媽不再要擔憂我在正式環境敲錯命令刪數據庫跑路了。ssh

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

構建鏈接

class Connection(Context):
    host = None
    user = None
    port = None
    ssh_config = None
    connect_timeout = None
    connect_kwargs = None
    ...
複製代碼

構建 Connection 對象的方式有不一樣的方式,例如你能夠將 host 寫成 "root@192.168.101.1:22" ,也能夠做爲3個參數分開寫。而 connect_kwargs 是字典對象,一般填服務器的登陸密碼或者密鑰。

上傳文件

run 方法用於執行命令,cd 進入指定目錄,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')
複製代碼

多臺服務器

若是是要在多臺服務器運行命令,簡單的辦法就是使用迭代,挨個服務器執行命令:

# web1,web2,mac1 都是服務器的名字,你也能夠用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) 參數說明:

  • *hosts: 能夠傳入多個主機名或IP
  • **kwargs 接收的參數能夠和Connection同樣,能夠指定密碼

你 get 了嗎? 獲取更多文章可關注公衆號 「Python之禪」

更多參考請點擊官方文檔: www.fabfile.org/

本文首發:foofish.net/fabric.html

相關文章
相關標籤/搜索