当前位置:
首页 > temp > 简明python教程 >
-
Python学习笔记—自动化部署【新手必学】
pexpect
Pexpect 是 Don Libes 的 Expect 语言的一个 Python 实现,是一个用来启动子程序,并使用正则表达式对程序输出做出特定响应,以此实现与其自动交互的 Python 模块。 Pexpect 的使用范围很广,可以用来实现与 ssh、ftp 、telnet 等程序的自动交互;可以用来自动复制软件安装包并在不同机器自动安装;还可以用来实现软件测试中与命令行交互的自动化。当然如果你还没学到自动化,建议可以先去小编的Python交流.裙 :一久武其而而流一思(数字的谐音)转换下可以找到了,里面有最新Python教程项目,多交流进步更快
-
import pexpect
-
import sys
-
-
child = pexpect.spawn('ssh std20@123.57.211.212')
-
child.logfile = sys.stdout
-
#fout = file('mylog.txt', 'w')
-
#child.logfile = fout
-
child.expect('password:')
-
child.sendline('std20')
-
child.expect('std20.*')
-
child.sendline('ls /')
-
child.expect('std20.*')
-
child.sendline('exit')
-
#coding=utf_8
-
-
from pexpect import pxssh
-
import sys
-
-
s = pxssh.pxssh()
-
s.logfile = sys.stdout
-
hostname = '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()
fabric
项目发布和运维的工作相当机械,频率还蛮高,导致时间浪费在敲大量重复的命令上。
修复bug什么的,测试,提交版本库(2分钟),ssh到测试环境pull部署(2分钟),rsync到线上机器A,B,C,D,E(1分钟),分别ssh到ABCDE五台机器,逐一重启(8-10分钟) = 13-15分钟
其中郁闷的是,每次操作都是相同的,命令一样,要命的是在多个机器上,很难在本机一个脚本搞定,主要时间都浪费在ssh,敲命令上了,写成脚本,完全可以一键执行,花两分钟看下执行结果。
安装
pip install fabric
入门示例
-
#fabfile.py
-
from fabric.api import run
-
-
def 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常用参数
- -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/itcast/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.passwords={'itcast@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('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 ...')
-
-
@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()
代码自动化部署
-
from fabric.api import *
-
-
env.user = 'itcast'
-
env.hosts = ['192.168.17.192', '192.168.17.193']
-
env.password = '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 remote_update():
-
with cd("/home/itcast/tmp/itcasthello"):
-
run("git checkout master")
-
run("git pull origin master")
-
-
@task
-
def deploy():
-
local_update()
-
remote_update()
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数