運(yùn)維管理器Fabric使用方法
Fabric的安裝
Fabric支持pip,easy_install或源碼方式安裝,很方便解決包依賴問題,(根據(jù)用戶環(huán)境,自行選擇pip或ease_install)
pip install fabric
easy_install fabric
源碼安裝不介紹了。
校驗(yàn)安裝結(jié)果,如果導(dǎo)入模塊沒有提示異常,則說明安裝成功:
root@Python_S6:~# python
Python 2.7.5+ (default, Sep 19 2013, 13:48:49)
[GCC 4.8.1] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import fabric
>>>
官網(wǎng)提供了一個簡單的入門示例:
root@Python_S6:/home/chart7/test/fabric# cat farbic.py
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from fabric.api import run
def host_type(): #定義一個任務(wù)函數(shù),通過run方法實(shí)現(xiàn)遠(yuǎn)程執(zhí)行'uname -s'命令
run('uname -s')
運(yùn)行結(jié)果如果下圖所示

命令引用默認(rèn)文件名為fabfile.py,如果使用非默認(rèn)文件名稱,則需通過'-f'來制定,如:fab -H 192.168.1.23,192.168.1.24 -f host_type.py host_type,如果管理機(jī)與目標(biāo)主機(jī)未配置密鑰認(rèn)證信任,將提示會輸入目標(biāo)主機(jī)對應(yīng)賬戶登錄密碼。
一、fab的常用參數(shù)
fab作為Fabric程序的命令入口,提供了豐富的參數(shù)調(diào)用,命令格式如下:
fab [options] <command>[:arg1,arg2=val2,host=foo,hosts='h1;h2',....]
下面列舉了常用的幾個參數(shù),更多參數(shù)可使用fab -help查看.
-l,顯示定義好的任務(wù)函數(shù)名;
-f,指定fab入口文件,默認(rèn)入口文件名為fabfile.py;
-g,指定網(wǎng)關(guān)設(shè)備,比如堡壘機(jī)環(huán)境,填寫堡壘機(jī)IP即可;
-H,指定目標(biāo)主機(jī),多臺主機(jī)用','號分隔;
-P,以異步并行方式運(yùn)行多個主機(jī)任務(wù),默認(rèn)為串行運(yùn)行;
-R,指定role(角色),以角色名區(qū)分不同業(yè)務(wù)組設(shè)備;
-t,設(shè)置設(shè)備連接超時(shí)時(shí)間;
-T,設(shè)置遠(yuǎn)程主機(jī)命令執(zhí)行超時(shí)時(shí)間;
-w,當(dāng)命令執(zhí)行失敗,發(fā)出警告,而非默認(rèn)終止任務(wù)
二、fabfile的編寫
fab命令是結(jié)合我們編寫的fabfile.py(其他文件名必須添加-f filename引用)來搭配使用,部分命令行參數(shù)可以通過相應(yīng)的方法來代替,使之更加靈活,列如"-H 192.168.1.23,192.168.1.24",我們可以通過定義env.hosts來實(shí)現(xiàn),如"env.hosts=[192.168.1.23,192.168.1.24]".fabfile的主體由多個自定義的任務(wù)函數(shù)組成,不同任務(wù)函數(shù)實(shí)現(xiàn)不同的操作邏輯,下面詳細(xì)介紹
三、全局屬性設(shè)定
env對象的作用是定義fabfile的全局設(shè)定,支持多個屬性,包括目標(biāo)主機(jī),用戶,密碼角色,各屬性說明如下:
env.host,定義目標(biāo)主機(jī),可以用IP或主機(jī)名表示,以Python的列表形式定義,如env.hosts=['192.168.1.23,192.168.1.24'].
env.exculde_hosts,排除指定主機(jī),如env.exclude_hosts=['192.168.1.23']
env.user,定義用戶名,如env.user="root"
env.port,定義目標(biāo)主機(jī)端口,如env.port = '22'
env.password,定義密碼,如env.password='123456'
env.passwords,與password功能一樣,區(qū)別在于不同主機(jī)不同密碼的應(yīng)用場景,需要注意的是,配置passwords時(shí)需要配置用戶,主機(jī),端口等信息,如:env.passwords = {'root@192.168.1.21:22':'123456',
'root@192.168.1.23:22':'3234234',
'root@192.168.1.24:23':'09887',
}
env.gateway,定義網(wǎng)關(guān)(中轉(zhuǎn),堡壘機(jī))IP,如env.gateway = '192.168.1.1'
env.roledefs,定義角色分組,比如web組與db組主機(jī)區(qū)分開來,定義如下:
env.roledefs = {
'webservers':['192.168.1.21','192.168.1.22','192.168.1.23'],
'dbservers':['192.168.1.24','192.168.1.25'],
}
引用時(shí)使用python修飾符的形式進(jìn)行,角色修飾符下面的任務(wù)函數(shù)為其作用域,下面來看一個示例:
@roles('webservers')
def webtask():
run('/etc/init.d/nginx start')
@roles('dbservers'):
def dbtask():
run('/etc/init.d/mysql start')
@roles('webservers','dbservers')
def publictask():
run('uptime')
def deploy():
execute(webtask)
execute(dbtask)
execute(publictask)
在命令執(zhí)行fab deploy就可以實(shí)現(xiàn)不同角色執(zhí)行不同的任務(wù)函數(shù)。
常用API
Fabric提供了一組簡單但功能強(qiáng)大的fabric.api命令集,簡單地調(diào)用這樣API就能完成大部分應(yīng)用場景需求,F(xiàn)abric支持常用的方法及說明如下:
local,執(zhí)行本地命令,如local:('uname -s');
lcd,切換本地目錄,如lcd:('/home');
cd,切換遠(yuǎn)程目錄,如cd:('/data/logs/');
run,執(zhí)行遠(yuǎn)程命令,如:run('free -m')
sudo,sudo方式執(zhí)行遠(yuǎn)程命令,如:sudo('/etc/init.d/httpd start');
put,上傳本地文件到遠(yuǎn)程主機(jī),如:put('/home/user.info','/data/user.info');
get,從遠(yuǎn)程主機(jī)下載文件到本地,如:get('/home/user.info','/data/user.info');
prompt,獲得用戶輸入信息,如:prompt('please input user password:');
confirm,獲得提示信息確認(rèn),如:confirm('Test failed,Continue[Y/N]');
reboot,重啟遠(yuǎn)程主機(jī),如reboot();
@task,函數(shù)修飾符,標(biāo)識符的函數(shù)為fab可調(diào)用,非標(biāo)記對fab不可見,純業(yè)務(wù)邏輯;
@runs_once,函數(shù)修飾符,標(biāo)識符的函數(shù)只會執(zhí)行一次,不受多臺主機(jī)影響;
示例1:查看本地與遠(yuǎn)程主機(jī)信息
本示例調(diào)用local()方法執(zhí)行本地命令,添加"@runs_once"修飾保證該任務(wù)函數(shù)只執(zhí)行一次。調(diào)用run()方法執(zhí)行遠(yuǎn)程命令,
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from fabric.api import *
env.user = 'root'
env.hosts = ['192.168.1.43','192.168.1.23','192.168.1.24']
env.port = '22'
env.password = '123456'
@runs_once #查看本地系統(tǒng)信息,當(dāng)有多臺主機(jī)時(shí)只運(yùn)行一次
def local_task(): #本地任務(wù)函數(shù)
local('uname -a')
def remote_task():
with cd('/data'): #with的作用是讓后面的表達(dá)式語句繼承當(dāng)前狀態(tài),實(shí)現(xiàn)cd /var && ls -l的效果
run('ls -l')
通過fab命令分別調(diào)用local_task任務(wù)函數(shù)運(yùn)行效果如下圖所示

結(jié)果中顯示了[192.168.1.23] Executing task 'local_task',但事實(shí)上并非在主機(jī)192.168.1.23上執(zhí)行任務(wù),而是返回Fabric主機(jī)本地的'uname -a'的執(zhí)行效果
調(diào)用remtoe_task任務(wù)函數(shù)的執(zhí)行結(jié)果如下圖所示

示例2;動態(tài)獲取遠(yuǎn)程目錄列表
本示例使用"@task"修飾符標(biāo)志入口函數(shù)go()對外部可以,配合"@runs_once"符等待接受用戶輸入,最后調(diào)用worktask()任務(wù)函數(shù)實(shí)現(xiàn)遠(yuǎn)程命令執(zhí)行,
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from fabric.api import *
env.user = 'root'
env.hosts = ['192.168.1.23','192.168.1.24']
env.password = '123456'
@runs_once #在主機(jī)遍歷過程中,只有一臺出發(fā)此函數(shù)
def input_raw():
return prompt("please input direcotry name:",default="/home")
def worktask(dirname):
run("ls -l %s" %dirname)
@task
def go():
getdirname = input_raw()
worktask(getdirname)
該示例實(shí)現(xiàn)了一個動態(tài)輸入遠(yuǎn)程目錄名稱,在獲取目錄列表的功能,由于我們只要求輸入一次,再顯示所有主機(jī)上該目錄的列表信息,調(diào)用了一個子函數(shù)input_raw(同時(shí)配置)@runs_once修飾符來達(dá)到此目的,執(zhí)行結(jié)果如下圖

文件上傳與執(zhí)行
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from fabric.api import *
from fabric.context_managers import *
from fabric.contrib.console import confirm
env.hosts=['192.168.1.23','192.168.1.24']
#假如所有主機(jī)密碼都不一樣,可以通過env.passwords字典變量一一指定
env.passwords = {
'root@192.168.1.23:22': '123456',
'root@192.168.1.24:22': '123456',
}
lpackpath="/home/a.tar.gz"
rpackpath="/tmp/install"
@task
def put_task():
run("mkdir -p /tmp/install")
with settings(warn_only=True):
result = put(lpackpath, rpackpath)
if result.failed and not confirm("put file failed, Continue[Y/N]?"):
abort("Aborting file put task!")
@task
def run_task():
with cd("/tmp/install"):
run("tar -zxvf a.tar.gz")
@task
def go():
put_task()
run_task()
相關(guān)文章
MongoDB學(xué)習(xí)筆記(六) MongoDB索引用法和效率分析
MongoDB中的索引其實(shí)類似于關(guān)系型數(shù)據(jù)庫,都是為了提高查詢和排序的效率的,并且實(shí)現(xiàn)原理也基本一致2013-07-07
無盤完美解決Windows Server 2012或2016無法安裝.NET Framework3.5的方法
今天小編就為大家分享一篇關(guān)于無盤完美解決Windows Server 2012或2016無法安裝.NET Framework3.5的方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-03-03
windows服務(wù)器如何創(chuàng)建.開頭(.well-known)的文件夾
國內(nèi)的云服務(wù)商騰訊云提供免費(fèi)有效期一年的SSL證書,申請過程中需要身份驗(yàn)證,需要dns域名解析或者服務(wù)器文件驗(yàn)證。如果想使用文件驗(yàn)證,必須創(chuàng)建一個以.開頭的文件,使用windows服務(wù)器如何創(chuàng)建.開頭的文件夾。2023-04-04
服務(wù)器錯誤碼500 501 502 503 504 505 詳解
這篇文章主要介紹了服務(wù)器錯誤碼500 501 502 503 504 505 詳解,需要的朋友可以參考下2015-07-07
windows+apache+mod_python配置django運(yùn)行環(huán)境
環(huán)境:windows2008, apache2.2, python2.5, mod_python-3.3.1.win32-py2.5-Apache2.2, django-1.0.2_final2012-06-06
MongoDB學(xué)習(xí)筆記(一) MongoDB介紹與安裝方法
最近開始學(xué)習(xí)非關(guān)系型數(shù)據(jù)庫MongoDB,卻在博客園上找不到比較系統(tǒng)的教程,很多資料都要去查閱英文網(wǎng)站,效率比較低下。本人不才,借著自學(xué)的機(jī)會把心得體會都記錄下來,方便感興趣的童鞋分享討論2013-07-07

