天天看點

fabric 自動化部署

fabric

項目釋出和運維的工作相當機械,頻率還蠻高,導緻時間浪費在敲大量重複的指令上。

修複bug什麼的,測試,送出版本庫(2分鐘),ssh到測試環境pull部署(2分鐘),rsync到線上機器A,B,C,D,E(1分鐘),分别ssh到ABCDE五台機器,逐一重新開機(8-10分鐘) = 13-15分鐘

其中郁悶的是,每次操作都是相同的,指令一樣,要命的是在多個機器上,很難在本機一個腳本搞定,主要時間都浪費在ssh,敲指令上了,寫成腳本,完全可以一鍵執行,花兩分鐘看下執行結果。

安裝

pip install fabric

入門示例

#fabfile.py
from fabric.api import run

def host_type():
    run('uname -s')
           

啟動

[email protected]:~/tmp/fab$ fab -H 127.0.0.1 host_type
[127.0.0.1] Executing task 'host_type'
[127.0.0.1] run: uname -s [127.0.0.1] Login password for 'itcast': [127.0.0.1] out: Linux [127.0.0.1] out: Done. Disconnecting from 127.0.0.1... done. [email protected]:~/tmp/fab$ fab -H 127.0.0.1 host_type [127.0.0.1] Executing task 'host_type' [127.0.0.1] run: uname -s [127.0.0.1] Login password for 'itcast': [127.0.0.1] out: Linux [127.0.0.1] out:       

fabric常用參數

  • -l : 顯示定義好的任務函數名
  • -f : 指定fab入口檔案,預設入口檔案名為fabfile.py
  • -H : 指定目标主機,多台主機用","号分割

fabric常用API

  • local : 執行本地指令,如:local('uname -s')
  • lcd : 切換本地目錄,如:lcd('/home')
  • cd : 切換遠端目錄,如:cd('/etc')
  • run : 執行遠端指令,如:run('free -m')
  • sudo : sudo方式執行遠端指令,如:sudo('touch /abc')
  • put : 上傳本地檔案到遠端主機,如:put('/hello', '/home/itcast/hello')
  • get : 從遠端主機下載下傳檔案到本地,如:get('/home/python/world', '/home/itcast/world')
  • reboot : 重新開機遠端主機,如:reboot()
  • @task : 函數裝飾器,辨別的函數為fab可調用的,非标記的對fab不可見,純業務邏輯
  • @runs_once : 函數裝飾器,辨別的函數隻會執行一次,不受多台主機影響

fabric全局屬性設定

  • env.host : 定義目标主機,如:env.host=['192.168.17.192', '192.168.17.193']
  • env.user : 定義使用者名,如:env.user="root"
  • env.port : 定義目标主機端口,預設為22,如:env.port="22"
  • env.password : 定義密碼,如:env.password="chuanzhi"
  • env.passwords : 不同的主機不同的密碼,如:env.passwords={'[email protected]:22':'chuanzhi', '[email protected]:22':'python'}

示例1:動态擷取遠端目錄清單

from fabric.api import *

env.hosts=['192.168.17.192', '192.168.17.193']
#env.password='python'
env.passwords = {
    '[email protected]:22':'python',
    '[email protected]:22':'python',
}

@runs_once
def input_raw():
    return prompt("please input directory name:", default="/home")

def workask(dirname):
    run('ls -l ' + dirname)

@task
def go():
    print('start ...')
    getdirname = input_raw()
    workask(getdirname)
    print('end ...')
           

  

示例2:上傳檔案并執行

from fabric.api import *

env.user = 'itcast'
env.hosts = ['192.168.17.192', '192.168.17.193']
env.password = 'python'

@task
@runs_once
def tar_task():
    with lcd('/home/itcast/testdemo'):
        local('tar zcvf demo.tar.gz demo.py')

@task
def put_task():
    run('mkdir -p /home/itcast/testdemo')
    with cd('/home/itcast/testdemo'):
        put('/home/itcast/testdemo/demo.tar.gz', '/home/itcast/testdemo/demo.tar.gz')

@task
def check_task():
    lmd5 = local('md5sum /home/itcast/testdemo/demo.tar.gz', capture=True).split(' ')[0]
    rmd5 = run('md5sum /home/itcast/testdemo/demo.tar.gz').split(' ')[0]
    if lmd5 == rmd5:
        print('OK ...')
    else:
        print('ERROR ...')

@task
def run_task():
    with cd('/home/itcast/testdemo'):
        run('tar zxvf demo.tar.gz')
        run('python demo.py')

@task
def go():
    tar_task()
    put_task()
    check_task()
    run_task()
           

  

代碼自動化部署

from fabric.api import *

env.user = 'itcast'
env.hosts = ['192.168.17.192', '192.168.17.193']
env.password = 'python'

@runs_once
@task
def local_update():
    with lcd("/home/itcast/tmp/itcasthello"):
        local("git add -A")
        local("git commit -m 'update'")
        local("git pull origin master")
        local("git push origin master")


@task
def remote_update():
    with cd("/home/itcast/tmp/itcasthello"):
        run("git checkout master")
        run("git pull origin master")

@task
def deploy():
    local_update()
    remote_update()
           

  

轉載于:https://www.cnblogs.com/alamZ/p/7198019.html