fabric的一些示例

fabric

项目发布和运维的工作相当机械,频率还蛮高,导致时间浪费在敲大量重复的命令上。

修复bug什么的,测试,提交版本库(2分钟)。ssh到测试环境pull部署(2分钟),rsync到线上机器
A,B,C,D,E(1分钟),分别ssh到ABCDE五台机器,逐一重启(810分钟)=1315分钟

其中郁闷的是,每次操作都是相同得到,命令一样,要命的是在多个机器上,很难再本机一个脚本搞定,
主要时间都浪费在ssh,敲命令上了,写成脚本,完全可以一键执行,花两分钟看下执行结果

安装:详见安装篇

from fabric.api import run

def host_test():
    run('uname -s')

fabric常用参数

  • -l:显示定义好的任务函数名
  • -f:指定fab人口文件,默认人口文件名为fabfile.py
  • -H:指定目标主机,多台主机用“,”号分割

fabric常用API

  • local:执行本地命令,如:local('uname -s')
  • lcd:切换本地目录,如:lcd('/home')
  • cd:切换远程目录,如:cd('/etc')
  • run:执行远程命令,如:run('free -m')
  • sudo:sudo方式执行远程命令,如:sudo('touch /abc')
  • put:上传本地文件到远程主机,如:put('/hello', '/home/itcast/hello')
  • get:从远程主机下载文件到本地,如:get('/home/python/world', '/home/itcase/world')
  • reboot:重启远程主机,如:reboot()
  • @task:函数装饰器,标识的函数为fab可调用的,非标记的对fab不可见,纯业务逻辑
  • @runs_once:函数装饰器,标识的函数只会执行一次,不受多台主机影响

fabric全局属性设定

  • env.host:定义目标主机,如:env.host=['192.168.17.192','192.168.17.193']
  • env.user:定义用户名,如:env.user="root"
  • env.port:定义目标主机端口,默认为22,如:env.port=“22”
  • env.password:定义密码,如:env.password="chuanzhi"
  • env.passwords:不同的主机不同的密码,如:env.passowrds={'itcase@192.168.17.192:22':'chuanzhi','itcast@192.168.17.193:22':'python'}
示例1:动态获取远程目录列表
from fabric.api import *
env.hosts=['192.168.17.192','192.168.17.193']
#env.password='python'
env.passwords = {
    'itcast@192.168.17.192:22':'python',
    'itcast@192.168.17.193:22':'python',
}

@runs_once:
def input_raw():
    return prompt("please input directory name",default="/home")
    
def workask(dirname):
    run('ls -l' + dirname)

@task
def go()
    print('start ...')
    getdirname = input_raw()
    workask(getdirname)
    print('end ...')
示例2:上传文件并执行
from fabric.api import *

env.user = 'itcast'
env.hosts = ['192.168.17.192', '192.168.17.193']
env.password = 'python'

@task
@runs_once
def tar_task():
    with lcd('/home/itcast/testdemo'):
        local('tar zcvf demo.tar.gz demo.py')

@task
def put_task():
    run('mkdir -p /home/itcast/testdemo')
    with cd('/home/itcast/testdemo'):
        put('/home/itcast/testdemo/demo.tar.gz', '/home/itcast/testdemo/demo.tar.gz')
        
@task
def check_task():
    lmd5 = local('md5sun /home/itcast/testdemo/demo.tar.gz', capture=Ture).split(' ')[0]
    rmd5 = run('md5sum /home/itcast/testdemo/demo.tar.gz').split(' ')[0]
    if lmd5 == rmd5
        print('OK ...')
    else:
        print('ERROR ... ')

@task
def run_task():
    with cd('/home/itcast/testdemo'):
        run('tar zxvf demo.tar.gz')
        run('python demo.py')

@task
def go():
    tar_task()
    put_task()
    check_task()
    run_task()
示例3:代码自动化部署
from fabric.api import *

env.user = 'itcast'
env.hosts = ['192.168.17.192', '192.168.17.193']
env.passoword = 'python'

@runs_once
@task
def local_update():
    with lcd("/home/itcast/tmp/itcasthello"):
        local("git add -A")
        local("git commit -m 'update'")
        local("git pull origin master")
        local("git push origin master")

@task
def remotr_update():
    with cd("/home/itcast/tmp/itcasthello"):
        run("git checkout master")
        run("git pull origin master")

@task
def deploy():
    local_update()
    remote_update()

Pexpect
Pexpect是Don Libes的Expect语言的一个Python实现,是一个用来启动子程序,并使用正则表达式对程序输出做出特定响应,
以此实现与其自动交互的Python模块,Pexpect的使用范围很广,可以用来实现与ssh、ftp、telnet等程序的自动交互;
可以用来自动复制软件安装包并在不同机器自动安装;还可以用来实现软件测试中与命令行交互的自动化。

import pexpect
import sys

child = pexpect.spawn('ssh root@192.168.1.64')
child.logfile = sys.stdout
child.expect('password:')
child.sendline('111111')
child.expect('root.*')
child.sendline('ll')
child.expect('root.*')
child.sendline('date -R')
child.expect('root.*')
child.sendline('exit')
#coding=utf_8

import sys
from pexpect import pxssh

s = pxssh.pxssh()
s.logfile = sys.stdout
hostname = '192.168.1.64'
username = 'root'
password = '111111'
s.login(hostname, username, password)
s.sendline('ll')
s.prompt()
s.sendline('whoami')
s.prompt()
s.logout
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • fabric 介绍 Fabic是一个python(2.5-2.7)库,用于简化使用ssh的应用程序部署,或系统管理...
    bdslinux阅读 7,933评论 3 4
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,797评论 19 139
  • fabric学习和实验 安装package:virtualenv [root@BIGDATA1 pip-9.0.1...
    jianwbj阅读 4,262评论 0 0
  • 部分内容转载自搜狗百科 cmd是command的缩写.即命令提示符(CMD),是在OS / 2 , Windows...
    青冥之上阅读 7,013评论 0 24
  • 致老婆: 昨天在车上我在听手机上的有声书,书中的内容讲的就是哈耶克流派的自由主义经济学观点。并结合了中国现实中是例...
    whatcanhumando阅读 2,224评论 1 1