Python的批量遠程管理和部署工具Fabric用法實例
本文實例講述了Python的批量遠程管理和部署工具Fabric用法。分享給大家供大家參考。具體如下:
Fabric是Python中一個非常強大的批量遠程管理和部署工具,常用于在多個遠程PC上批量執(zhí)行SSH任務(wù).
常見的使用方法大概總結(jié)如下:
1. 首先,要將批量執(zhí)行的任務(wù)寫入到一個fabfile.py中,
from fabric.api import run, local, roles, env, cd
env.hosts=[
'192.168.1.110',
'192.168.1.111',
'192.168.1.112'
]
env.user="username"
env.password="password"
env.port=22
#env.parallel=True
#env.skip_bad_hosts=True
#env.timeout=1
#env.warn_only=True
# local用于在本地PC執(zhí)行命令.
# run用于在遠程PC執(zhí)行命令.
def ls():
with cd('/home/workspace/project'):
local('touch 1.log')
with cd('/home/workspace/project2'):
local('touch 2.log')
#@parallel, 可以設(shè)置是否并行執(zhí)行
#@serial
def pull():
with cd('/home/workspace/project'):
run('git pull')
def clean():
with cd('/home/workspace/project'):
run('bash clean.sh')
@hosts('192.168.1.113')
def robot(device):
with cd('/home/workspace/project'):
run('bash run.sh %s robot && sleep 1' % device)
以上就是一個簡單的fabfile.py, 其中定義的函數(shù)均對應一個fab中的可執(zhí)行命令.
其中有兩個小的注意事項:
A.在遠程機器的run.sh中如果要執(zhí)行一些非系統(tǒng)常見的工具,最好指定為絕對路徑. 且可以適當?shù)厥褂胣ohup的方式.
B.執(zhí)行其他腳本或者命令后最好加上sleep,以防止Fabric過早地關(guān)閉與遠程PC連接的session,而導致執(zhí)行任務(wù)失敗.
2. 執(zhí)行過程: fabric執(zhí)行會默認選取當前目錄下的fabfile.py文件,
fab pull
fab robot:hosts="192.168.1.115",device=5560
可以通過hosts參數(shù)給fabric傳入指定的遠程PC, 該hosts參數(shù)的優(yōu)先級比env.hosts的要高.
也可以給fab中的命令傳遞參數(shù),如device.
此外,還可以通過fab -f otherFabFile.py clean來指定其他的fabric文件.
如果需要并行執(zhí)行的話,也可以傳遞參數(shù)如fab -P -z 15 pull, 15表示并行執(zhí)行的PC數(shù)量.
以上,只是一些簡單的用法,如果需要更高級的用法,可以關(guān)注該項目的github主頁 https://github.com/fabric/fabric.
希望本文所述對大家的Python程序設(shè)計有所幫助。
相關(guān)文章
Python設(shè)計模式結(jié)構(gòu)型享元模式
這篇文章主要介紹了Python享元模式,享元模式即Flyweight Pattern,指運用共享技術(shù)有效地支持大量細粒度的對象,下面和小編一起進入文章了解更多詳細內(nèi)容吧2022-02-02Python+Selenium實現(xiàn)瀏覽器的控制操作
這篇文章主要為大家詳細介紹了Python+Selenium如何實現(xiàn)常見的瀏覽器控制操作,例如:瀏覽器參數(shù)設(shè)置、控制瀏覽器前進/后退等,感興趣的可以了解一下2022-09-09opencv中圖像疊加/圖像融合/按位操作的實現(xiàn)
這篇文章主要介紹了opencv中圖像疊加/圖像融合/按位操作的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04