本文共 4225 字,大约阅读时间需要 14 分钟。
目录
Pexpect 是 Don Libes 的 Expect 语言的一个 Python 实现,是一个用来启动子程序,并使用正则表达式对程序输出做出特定响应,以此实现与其自动交互的 Python 模块。 Pexpect 的使用范围很广,可以用来实现与 ssh、ftp 、telnet 等程序的自动交互;可以用来自动复制软件安装包并在不同机器自动安装;还可以用来实现软件测试中与命令行交互的自动化。
import pexpectimport syschild = pexpect.spawn('ssh std20@123.57.211.212')child.logfile = sys.stdout#fout = file('mylog.txt', 'w')#child.logfile = foutchild.expect('password:')child.sendline('std20')child.expect('std20.*')child.sendline('ls /')child.expect('std20.*')child.sendline('exit')
#coding=utf_8from pexpect import pxsshimport syss = pxssh.pxssh()s.logfile = sys.stdouthostname = '123.57.211.212'username = 'std20'password = 'std20's.login(hostname, username, password)s.sendline('ls /')s.prompt() #匹配系统提示符s.sendline('whoami')s.prompt() s.logout()
项目发布和运维的工作相当机械,频率还蛮高,导致时间浪费在敲大量重复的命令上。
修复bug什么的,测试,提交版本库(2分钟),ssh到测试环境pull部署(2分钟),rsync到线上机器A,B,C,D,E(1分钟),分别ssh到ABCDE五台机器,逐一重启(8-10分钟) = 13-15分钟
其中郁闷的是,每次操作都是相同的,命令一样,要命的是在多个机器上,很难在本机一个脚本搞定,主要时间都浪费在ssh,敲命令上了,写成脚本,完全可以一键执行,花两分钟看下执行结果。
安装
pip install fabric
入门示例
#fabfile.pyfrom fabric.api import rundef host_type(): run('uname -s')
启动
itcast@ubuntu:~/tmp/fab$ fab -H 127.0.0.1 host_type[127.0.0.1] Executing task 'host_type'[127.0.0.1] run: uname -s[127.0.0.1] Login password for 'itcast': [127.0.0.1] out: Linux[127.0.0.1] out: Done.Disconnecting from 127.0.0.1... done.itcast@ubuntu:~/tmp/fab$ fab -H 127.0.0.1 host_type[127.0.0.1] Executing task 'host_type'[127.0.0.1] run: uname -s[127.0.0.1] Login password for 'itcast': [127.0.0.1] out: Linux[127.0.0.1] out:
fabric常用参数
fabric常用API
fabric全局属性设定
示例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_oncedef input_raw(): return prompt("please input directory name:", default="/home")def workask(dirname): run('ls -l ' + dirname)@taskdef 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_oncedef tar_task(): with lcd('/home/itcast/testdemo'): local('tar zcvf demo.tar.gz demo.py')@taskdef 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')@taskdef check_task(): lmd5 = local('md5sum /home/itcast/testdemo/demo.tar.gz', capture=True).split(' ')[0] rmd5 = run('md5sum /home/itcast/testdemo/demo.tar.gz').split(' ')[0] if lmd5 == rmd5: print('OK ...') else: print('ERROR ...')@taskdef run_task(): with cd('/home/itcast/testdemo'): run('tar zxvf demo.tar.gz') run('python demo.py')@taskdef go(): tar_task() put_task() check_task() run_task()
代码自动化部署
from fabric.api import *env.user = 'itcast'env.hosts = ['192.168.17.192', '192.168.17.193']env.password = 'python'@runs_once@taskdef 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")@taskdef remote_update(): with cd("/home/itcast/tmp/itcasthello"): run("git checkout master") run("git pull origin master")@taskdef deploy(): local_update() remote_update()
转载地址:http://xjxmi.baihongyu.com/