Python自动化部署工具Fabric的简单上手指南


Posted in Python onApril 19, 2016

Fabric 是基于 SSH 协议的 Python 工具,相比传统的 ssh/scp 方式,用 Python 的语法写管理命令更易读也更容易扩展,管理单台或者多台机器犹如本地操作一般。

官网地址:http://fabfile.org

安装
省略python、pip管理工具安装过程

pip install fabric

验证是否安装成功
进入python编辑模式,输入代码,无错即表示成功安装

from fabric.api import local

fabric版hello world
fabric 默认文件fabfile.py,当然如果不想用这个名字,需要加-f参数

创建fabfile.py文件

vim fabrile.py

编辑代码

#coding:utf-8
from fabric.api import local#
def hello():
   # local函数用来执行本地命令
   local('echo "hello wolrd!"')

执行代码

fab hello

可以通过fab -l查看可以执行的任务,当前为hello函数
运行结果

[localhost] local: echo "hello world!"
hello world!
Done.


传统维护方法:

$ ssh x.x.x.x 'uname -a' -- 输出略

Fabric 示例:

$ cat fabfile.py
from fabric.api import run
def uname():
  run('uname -a')
$ fab -H x.x.x.x uname -- 输出略

肉眼直观看上去,貌似比 ssh 方式要写不少代码,但是基于 ssh 方式中间可控环节比较少,例如:你想判断某服务是否已经启动,没有启动则执行启动等等操作。ssh 命令式的做法稍显麻烦。(当然龌龊一点可以在被操作机器上写好一个脚本,ssh 调用这个脚本)

说几个 Fabric 的优点吧:

  • 角色定义
  • 代码易读
  • 封装了本地、远程操作(还需要自己封装system/popen/ssh操作么?)
  • 参数灵活(动态指定 host/role 等,还有并发执行 基于multiprocessing )
  • 完整的日志输出

罗列的这些,其实日常工作里基本都有类似的封装了,但是有现成的一个成熟的工具,干啥不用呢?对吧。

常用的配置:

  • env.host           -- 主机ip,当然也可以-H参数指定
  • env.password       -- 密码,打好通道的请无视
  • env.roledefs       -- 角色分组,比如:{'web': ['x', 'y'], 'db': ['z']}
  • fab -l             -- 显示可用的task(命令)
  • fab -H             -- 指定host,支持多host逗号分开
  • fab -R             -- 指定role,支持多个
  • fab -P             -- 并发数,默认是串行
  • fab -w             -- warn_only,默认是碰到异常直接abort退出
  • fab -f             -- 指定入口文件,fab默认入口文件是:fabfile/fabfile.py

更多请参考:fab --help

常用的函数:

  • local('pwd')                     -- 执行本地命令
  • lcd('/tmp')                      -- 切换本地目录
  • cd('/tmp')                       -- 切换远程目录
  • run('uname -a')                  -- 执行远程命令
  • sudo('/etc/init.d/nginx start')  -- 执行远程sudo,注意pty选项

 示例1:管理远程 nginx 服务

$ cat fabfile.py
from fabric.api import *
@task
def nginx_start():
  ''' nginx start '''
sudo('/etc/init.d/nginx start')

@task
def nginx_stop():
  ''' nginx stop '''
  sudo('/etc/init.d/nginx stop')

   

$ fab --list   -- 查看可用命令
Available commands:

  nginx_start nginx start 
  nginx_stop  nginx stop

$ fab -H x.x.x.x nginx_start -- 启动 nginx

示例2:基于角色

$ cat fabfile.py
from fabric.api import *
env.roledefs = {'nginx': ['x.x.x.x', 'y.y.y.y'], 'mysql': 'z.z.z.z'}
@task
def mysql_start()
  ''' mysql start '''
  sudo('/etc/init.d/mysql start')

   

$ fab --list   -- 查看可用命令
Available commands:

  nginx_start nginx start 
  nginx_stop  nginx stop
  mysql_start mysql start

$ fab -R nginx nginx_start -- 启动 nginx
$ fab -R mysql mysql_start -- 启动 mysql

示例3:混合本地和远程操作

$ cat fabfile
def hello():
  ''' test hello '''
  with lcd('/tmp'): # 切换到 /tmp 目录下
    local('svn co http://xxx xxx') # check 代码到本地
    local('tar czf xxx.tar.gz xxx/') # 压缩本地包
    put('xxx.tar.gz', '/tmp') # 上传压缩包到远程 /tmp 目录下
  with cd('/tmp'):  # 切换到远程 /tmp 目录
    run('tar zxf xxx.tar.gz') # 远程解压

是不是看上去都是像本地一样?对吧。

示例4:多个目标服务器
相同密码或者手动输入:

env.hosts = ['root@ip1:22',root@ip2:22]

不同密码或者不想手动输入(此方法也可定义不角色一组服务器):

#coding:utf-8
from fabric.api import local,cd,put,lcd,env,run,execute,roles
env.roledefs = {
 'role1':['root@ip1:22',],
 'role2':['root@ip2:22',]
}
env.passwords={
 'root@ip1:22':'pwd1',
 'root@ip2:22':'pwd2'
}
@roles('role1')
def role1():
 with cd('/tmp'):
   run('ls -l')
@roles('role2')
def role2():
 with cd('/tmp'):
   run('ls')
def task():
 execute(role1)
 execute(role2)
Python 相关文章推荐
python读文件逐行处理的示例代码分享
Dec 27 Python
Python之PyUnit单元测试实例
Oct 11 Python
DJANGO-ALLAUTH社交用户系统的安装配置
Nov 18 Python
查看Django和flask版本的方法
May 14 Python
TensorFlow数据输入的方法示例
Jun 19 Python
Django网络框架之HelloDjango项目创建教程
Jun 06 Python
Python初学者常见错误详解
Jul 02 Python
python多线程+代理池爬取天天基金网、股票数据过程解析
Aug 13 Python
python2.7的flask框架之引用js&css等静态文件的实现方法
Aug 22 Python
Django 自定义分页器的实现代码
Nov 24 Python
From CSV to SQLite3 by python 导入csv到sqlite实例
Feb 14 Python
python collections模块的使用
Oct 16 Python
python实现简单socket通信的方法
Apr 19 #Python
python实现域名系统(DNS)正向查询的方法
Apr 19 #Python
python安装与使用redis的方法
Apr 19 #Python
Python实现文件复制删除
Apr 19 #Python
利用Python获取赶集网招聘信息前篇
Apr 18 #Python
Python Sql数据库增删改查操作简单封装
Apr 18 #Python
python使用paramiko实现远程拷贝文件的方法
Apr 18 #Python
You might like
php实现查询百度google收录情况(示例代码)
2013/08/02 PHP
小谈php正则提取图片地址
2014/03/27 PHP
ThinkPHP独立分组使用的注意事项
2014/11/25 PHP
Linux系统下php获得系统分区信息的方法
2015/03/30 PHP
通过jQuery打造支持汉字,拼音,英文快速定位查询的超级select插件
2010/06/18 Javascript
jQuery文本框(input textare)事件绑定方法教程
2013/04/24 Javascript
纯JavaScript代码实现移动设备绘图解锁
2015/10/16 Javascript
javascript基础语法学习笔记
2016/01/04 Javascript
ionic js 复选框 与普通的 HTML 复选框到底有没区别
2016/06/06 Javascript
jQuery购物网页经典制作案例
2016/08/19 Javascript
jQuery实现表格隔行及滑动,点击时变色的方法【测试可用】
2016/08/20 Javascript
jquery  实现轮播图详解及实例代码
2016/10/12 Javascript
概述BootStrap中role="form"及role作用角色
2016/12/08 Javascript
Vue.js bootstrap前端实现分页和排序
2017/03/10 Javascript
node.js中实现kindEditor图片上传功能的方法教程
2017/04/26 Javascript
Axios学习笔记之使用方法教程
2017/07/21 Javascript
关于jquery layui弹出层的使用方法
2018/04/21 jQuery
详解JavaScript添加给定的标签选项
2018/09/17 Javascript
JavaScript享元模式原理与用法实例详解
2020/03/09 Javascript
vue根据条件不同显示不同按钮的操作
2020/08/04 Javascript
Postman环境变量全局变量使用方法详解
2020/08/13 Javascript
从Python程序中访问Java类的简单示例
2015/04/20 Python
python中requests使用代理proxies方法介绍
2017/10/25 Python
python监控键盘输入实例代码
2018/02/09 Python
python顺序的读取文件夹下名称有序的文件方法
2018/07/11 Python
python使用threading.Condition交替打印两个字符
2019/05/07 Python
如何将tensorflow训练好的模型移植到Android (MNIST手写数字识别)
2020/04/22 Python
Python 利用argparse模块实现脚本命令行参数解析
2020/12/28 Python
HTML5轻松实现全屏视频背景的示例
2018/04/23 HTML / CSS
美国户外烹饪产品购物网站:Outdoor Cooking
2020/01/10 全球购物
护理专业自荐信
2013/12/03 职场文书
设计总监岗位职责
2013/12/07 职场文书
中式结婚主持词
2014/03/14 职场文书
什么是就业协议书
2014/04/17 职场文书
幼儿园亲子活动总结
2014/04/26 职场文书
MySQL系列之九 mysql查询缓存及索引
2021/07/02 MySQL