fabric---Python中的批量遠端管理和部署工具

來源:互聯網
上載者:User

fabric---Python中的批量遠端管理和部署工具

Fabric是Python中一個非常強大的批量遠端管理和部署工具,常用於在多個遠程PC上批量執行SSH任務.

常見的使用方法大概總結如下:

1, 首先,要將批量執行的任務寫入到一個fabfile.py中,

 

# -*- coding:utf-8 -*-from fabric.api import run, local, roles, env, cdenv.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執行命令.# run用於在遠程PC執行命令.def ls():    with cd('/home/workspace/project'):        local('touch 1.log')    with cd('/home/workspace/project2'):        local('touch 2.log') #@parallel, 可以設定是否並存執行#@serialdef 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, 其中定義的函數均對應一個fab中的可執行命令.

 

其中有兩個小的注意事項,

A,在遠程機器的run.sh中如果要執行一些非系統常見的工具,最好指定為絕對路徑. 且可以適當地使用nohup的方式.

B,執行其他指令碼或者命令後最好加上sleep,以防止Fabric過早地關閉與遠程PC串連的session,而導致執行任務失敗.

2, 執行過程: fabric執行會預設選取目前的目錄下的fabfile.py檔案,

fab clean

fab pull

fab robot:hosts="192.168.1.115",device=5560

可以通過hosts參數給fabric傳入指定的遠程PC, 該hosts參數的優先順序比env.hosts的要高.

也可以給fab中的命令傳遞參數,如device.

此外,還可以通過fab -f otherFabFile.py clean來指定其他的fabric檔案.

以上,只是一些簡單的用法,如果需要更進階的用法,可以關注該項目的github首頁 https://github.com/fabric/fabric.


 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.