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

354次阅读  |  发布于5年以前

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 的优点吧:

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

常用的配置:

更多请参考: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)

Copyright© 2013-2020

All Rights Reserved 京ICP备2023019179号-8