Fabric的fabfile的編寫詳解

一 點睛

fab命令是結合我們編寫的fabfile.py(其他文件名須添加-f filename 引用)來搭配使用的,部分命令行參數可以通過相應的方法來代替,使之更加靈活,例如“-H 192.168.1.21,192.168.1.22”,我們可以通過定義env.hosts來實現,如“env.hosts=['192.168.1.21','192.168.1.22']”。

fabfile的主體由多個自定義的任務函數組成,不同任務函數實現不同的操作邏輯。

二 全局屬性設定

  • evn對象的作用是定義fabfile的全局設定,支持多個屬性,包括目標主機、用戶、密碼、角色等,各屬性說明如下:

  • env.host:定義目標主機,可以用IP或主機名錶示,以Python的列 表形式定義,如env.hosts=['192.168.1.21','192.168.1.22']。 

  • env.exclude_hosts:排除指定主機,如env.exclude_hosts= ['192.168.1.22']。 

  • env.user:定義用戶名,如env.user="root"。 

  • env.port:定義目標主機端口,默認爲22,如env.port="22"。 

  • env.password:定義密碼,如env.password='KSJ3548t7d'。 

  • env.passwords:與password功能一樣,區別在於不同主機不同密碼的應用場景,需要注意的是,配置passwords時需配置用戶、主機、 端口等信息,如:

env.passwords = {
    '[email protected]:22': 'SJk348ygd',
    '[email protected]:22': 'KSh458j4f',
    '[email protected]:22': 'KSdu43598' 
}
  • env.gateway:定義網關(中轉、堡壘機)IP,如 env.gateway='192.168.1.23'。

  • env.deploy_release_dir:自定義全局變量,格式:env.+“變量名 稱”,如env.deploy_release_dir、env.age、env.sex等。

  • env.roledefs:定義角色分組,比如web組與db組主機區分開來, 定義如下:

env.roledefs = {
    'webservers': ['192.168.1.21', '192.168.1.22', '192.168.1.23', '192.168.1.24'],
    'dbservers': ['192.168.1.25', '192.168.1.26'] 
}

引用時使用Python修飾符的形式進行,角色修飾符下面的任務函數爲其作用域,下面來看一個示例:

@roles('webservers') 
def webtask():
    run('/etc/init.d/nginx start') 
@roles('dbservers') 
def dbtask():
    run('/etc/init.d/mysql start') 
@roles ('webservers', 'dbservers') 
def pubclitask():
    run('uptime') 
def deploy():
    execute(webtask)
    execute(dbtask)
    execute(pubclitask)

在命令行執行#fab deploy就可以實現不同角色執行不同的任務函數了。

三 常用API

Fabric提供了一組簡單但功能強大的fabric.api命令集,簡單地調用這些API就能完成大部分應用場景需求。

Fabric支持常用的方法及說明如 下:

  • local:執行本地命令,如:local('uname-s'); 

  • run:執行遠程命令,如:run('free-m');

  • lcd:切換本地目錄,如:lcd('/home'); 

  • cd:切換遠程目錄,如:cd('/data/logs');

  • sudo:sudo方式執行遠程命令,如:sudo('/etc/init.d/httpd start');

  • put:上傳本地文件到遠程主機,如: put('/home/user.info','/data/user.info');

  • get:從遠程主機下載文件到本地,如: get('/data/user.info','/home/root.info');

  • prompt:獲得用戶輸入信息,如:prompt('please input user password:');

  • confirm:獲得提示信息確認,如:confirm("Tests failed.Continue[Y/N]?");

  • reboot:重啓遠程主機,如:reboot();

  • @task:函數修飾符,標識的函數爲fab可調用的,非標記對fab不可見,純業務邏輯;

  • @runs_once:函數修飾符,標識的函數只會執行一次,不受多臺主機影響。

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章