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()
Python学习笔记—自动化部署【新手必学】的更多相关文章
- Python基础语法总结【新手必学】
前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:weixin_45189038直接上知识点: 1. 注释 单行注释: ...
- Python自定义包引入【新手必学】
前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:sys_song python中的Module是比较重要的概念.常见的情 ...
- Python学习零基础<入门必学>
1. 注释注释 是任何存在于 # 号右侧的文字,其主要用作写给程序读者看的笔记. 2. 字面常量一个字面常量(Literal Constants)的例子是诸如 5.1.23 这样的数字,或者是如 这是 ...
- Python开发五子棋游戏【新手必学】
五子棋源码,原创代码,仅供 python 开源项目学习.目前电脑走法笨笨的,下一期版本会提高电脑算法ps:另外很多人在学习Python的过程中,往往因为遇问题解决不了或者没好的教程从而导致自己放弃,为 ...
- Python入门知识总结【新手必学】
Python 基础学习输入和输出list 和 tuple条件判断循环dict 和 set感觉python这门语言用途较广,先熟悉下其语法.PS:另外很多人在学习Python的过程中,往往因为没有好的教 ...
- Python学习笔记(十三)
Python学习笔记(十三): 模块 包 if name == main 软件目录结构规范 作业-ATM+购物商城程序 1. 模块 1. 模块导入方法 import 语句 import module1 ...
- Python 学习笔记 - 不断更新!
Python 学习笔记 太久不写python,已经忘记以前学习的时候遇到了那些坑坑洼洼的地方了,开个帖子来记录一下,以供日后查阅. 摘要:一些报错:为啥Python没有自增 ++ 和自减 --: 0x ...
- 近期Python学习笔记
近期Python 学习笔记--一篇文入门python 作者:Pleiades_Antares(www.cnblogs.com/irischen) 写在前面的话 想学Python已经许久,一年多以前(应 ...
- Deep learning with Python 学习笔记(10)
生成式深度学习 机器学习模型能够对图像.音乐和故事的统计潜在空间(latent space)进行学习,然后从这个空间中采样(sample),创造出与模型在训练数据中所见到的艺术作品具有相似特征的新作品 ...
随机推荐
- C++中对C的扩展学习新增语法——namespace
NAMESPACE语法 namespace主要解决了命名冲突的问题,语法如下 Namespace注意事项: namespace中可以定义常量.变量.函数.结构体.枚举.类等. namespace 只能 ...
- suseoj 1212: 推箱子问题(bfs)
1212: 推箱子问题 时间限制: 1 Sec 内存限制: 128 MB提交: 60 解决: 13[提交][状态][讨论版][命题人:liyuansong] 题目描述 码头仓库是划分为n×m个格子 ...
- nyoj 975-关于521 (EOF)
975-关于521 内存限制:64MB 时间限制:1000ms 特判: No 通过数:5 提交数:46 难度:2 题目描述: Acm队的流年对数学的研究不是很透彻,但是固执的他还是想一头扎进去. 浏览 ...
- ArcGIS API For Javascript :双屏(多屏)地图联动的方法
在遇到地图对比的应用场景下,我们需要双屏地图或者多屏地图来满足我们的业务需求. 解决思路:首先生成两份(多份)地图,然后通过监听地图缩放拖拽,用地图四至将不同的地图对象做绑定,实现多地图联动. 前端部 ...
- MySQL 5.7 - 通过 BINLOG 恢复数据
日常开发,运维中,经常会出现误删数据的情况.误删数据的类型大致可分为以下几类: 使用 delete 误删行 使用 drop table 或 truncate table 误删表 使用 drop dat ...
- Chocolatey初体验
新电脑安装Nodejs时发现安装包提示是否自动安装Chocolatey,之前没看到过这个名词,于是搜索了下,发现Chocolatey是Windows平台的包管理工具,类似于Linux的yum/apt- ...
- python2的编码问题小结
对于python2,经常会遇到编码问题,在此小记一下. Python2默认的编码解码方式是ascii码,这点要牢记. windows系统默认是gbk编码的,可以使用chcp查看:936,那就是GBK简 ...
- 2019-10-9:渗透测试,基础学习,php文件上传,mysql基础
header("Content-Type:text/html;charst="utf-8")设置头部信息,解决编码问题setcookie("loginStrin ...
- 新闻实时分析系统 Spark Streaming实时数据分析
1.Spark Streaming功能介绍1)定义Spark Streaming is an extension of the core Spark API that enables scalable ...
- 【开发工具 - MySQL】之不能插入中文的问题
新安装的MySQL数据库,在安装的时候设置了字体为UTF8,但在使用insert语句插入中文的时候还是会报错. 具体解决方法:在MySQL控制台中输入以下设置代码: SET character_set ...