Python自动化部署工具Fabric的简单上手指南
Fabric 是基于 SSH 协议的 Python 工具,相比传统的 ssh/scp 方式,用 Python 的语法写管理命令更易读也更容易扩展,管理单台或者多台机器犹如本地操作一般。 官网地址:http://fabfile.org 安装 pip install fabric 验证是否安装成功 from fabric.api import local fabric版hello world 创建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 的优点吧:
罗列的这些,其实日常工作里基本都有类似的封装了,但是有现成的一个成熟的工具,干啥不用呢?对吧。 常用的配置:
更多请参考:fab --help 常用的函数:
示例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) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |