遠端部署工具Fabric詳解(支援Python3)

2022-09-29 12:42:09 字數 2919 閱讀 7554

前言

如果你搜一圈 "fabric "關鍵字,你會發現 90% 的資料都是過時的,因為現在 fabric 支援 python3,但是它又不相容舊版 fabric。所以,如果你按照那些教程去操作的話根本跑不通。

如果你還沒用過 fabric,那麼這篇文章就是幫你快速上手 fabric 的。不管你現在用不用,先了解了以後也用得著。

平時我們的開發流程是這樣,經過幾個月奮戰,專案終於開發完了,測試也沒問題了,我們就把**提交到 github 那樣的託管平台,準備部署到正式環境。你小心翼翼地登入到正式伺服器,進入到專案目錄中,把**從遠端倉庫拉下來,然czsaf後啟動程式。後面每次有新功能發布或者哪怕只是修改了乙個小小的 bug 時,你都要執行重複的操作,登入伺服器,切換到指定目錄,拉取**,重啟服務。

其實這種操作非常繁瑣,也沒什麼技術含量,還容易出問題,於是 fabric 出場了。fabric 是乙個遠端部署神器,它可以在本地執行遠端伺服器的命令。

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

安裝 fabric

$ pip install fabric --upgrade

注意,如果你安裝的是舊版的 fabric,那麼新版的 fabric 是不相容舊版的,目前 fabric 有三個版本,fabric1 就是以前的 fabric,只支援 python2,已不推薦使用,而 fabric2 就是現在的 fabric,同時支援 python2 和 python3, 也是官方強烈推薦的版本, 還有乙個 fabric3,這是網友從舊版的 fabric1 轉殖過來的非官方版本,但是相容 fabric1,也支援 python2 和 python3。

最新的 fabric 不需要 fabfile.py 檔案, 也不需要 fab 命令,而現在網程式設計客棧絡上幾乎所有的教程、資料都還是基於 fabric1 寫的,當你在看那些教程的時候,注意甄別。 而新版 fabric 提供的 api 非常簡單。

執行命令

先看個例子,下面是一段部署指令碼

# deploy.py

# 1. 建立乙個遠端連線

# 2. 進入指定目錄

# 3. 在指定目錄下面執行重啟命令

from fabric import connection

def main():

# ip 我是隨便填czsaf的

# 如果你的電腦配了ssh免密碼登入,就czsaf不需要 connect_kwargs 來指定密碼了。

c = connection("[email protected]", connect_kwargs=)

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

執行完成後,最新**就已經部署到正式環境並重啟了服務,是不是非常方便,媽媽再也不要擔心我在正式環境敲錯命令刪資料庫跑路了。

fabric 不僅支援 linux,而且在 windows 平台也能很好的執行,在中小型專案,它是非常不錯的運維工具,有了 frabic ,管理上百臺伺服器都不成問題。

構建連線

class connection(context):

host = none

user = none

port = none

ssh_config = none

connect_timeout = none

connect_kwargs = none

...構建 connection 物件的方式有不同的方式,例如你可以將 host 寫成 "[email protected]: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= )

pool.put('myfiles.tgz', '/opt/mydata')

pool.run('tar -c /opt/mydata -xzvf /opt/mydata/myfiles.tgz')

group(*hosts, **kwargs) 引數說明:

本文完,你 get 了嗎?

本文標題: 遠端部署工具fabric詳解(支援python3)

本文位址:

遠端部署神器 Fabric,支援 Python3

如果你搜一圈 fabric 關鍵字,你會發現 90 的資料都是過時的,因為現在 fabric 支援 python3,但是它又不相容舊版 fabric。所以,如果你按照那些教程去操作的話根本跑不通。如果你還沒用過 fabric,那麼這篇文章就是幫你快速上手 fabric 的。不管你現在用不用,先了解了...

自動化部署工具Fabric簡介

在持續整合 灰度發布越來越流行的今天,模組在預覽或生產環境的部署流程自動化顯得越來越重要。本文要介紹的fabric就是乙個幫助我們在上線時減少重複 繁瑣操作的自動化部署利器,對於缺乏成熟運維平台的眾多小公司的運維或開發人員來說,掌握這個工具是有必要的。在系統運維和部署自動化領域,與fabric類似的...

Python 自動化部署 fabric 使用詳解

寫在前面 本文使用的是python2.7 fabric1.14 目前fabric還是使用python2居多 1 fabric入門 建立的檔案的檔名盡量為fabfile.py 內容為 coding utf 8 from fabric.api import task 裝飾器,表示是乙個任務 runs o...