前言
本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理。
作者:唯恋殊雨

 

目录

pexpect

fabric


pexpect

Pexpect 是 Don Libes 的 Expect 语言的一个 Python 实现,是一个用来启动子程序,并使用正则表达式对程序输出做出特定响应,以此实现与其自动交互的 Python 模块。 Pexpect 的使用范围很广,可以用来实现与 ssh、ftp 、telnet 等程序的自动交互;可以用来自动复制软件安装包并在不同机器自动安装;还可以用来实现软件测试中与命令行交互的自动化。当然如果你还没学到自动化,建议可以先去小编的Python交流.裙 :一久武其而而流一思(数字的谐音)转换下可以找到了,里面有最新Python教程项目,多交流进步更快

  1.  
    import pexpect
  2.  
    import sys
  3.  
     
  4.  
    child = pexpect.spawn('ssh std20@123.57.211.212')
  5.  
    child.logfile = sys.stdout
  6.  
    #fout = file('mylog.txt', 'w')
  7.  
    #child.logfile = fout
  8.  
    child.expect('password:')
  9.  
    child.sendline('std20')
  10.  
    child.expect('std20.*')
  11.  
    child.sendline('ls /')
  12.  
    child.expect('std20.*')
  13.  
    child.sendline('exit')
  1.  
    #coding=utf_8
  2.  
     
  3.  
    from pexpect import pxssh
  4.  
    import sys
  5.  
     
  6.  
    s = pxssh.pxssh()
  7.  
    s.logfile = sys.stdout
  8.  
    hostname = '123.57.211.212'
  9.  
    username = 'std20'
  10.  
    password = 'std20'
  11.  
    s.login(hostname, username, password)
  12.  
    s.sendline('ls /')
  13.  
    s.prompt() #匹配系统提示符
  14.  
    s.sendline('whoami')
  15.  
    s.prompt()
  16.  
    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

入门示例

  1.  
    #fabfile.py
  2.  
    from fabric.api import run
  3.  
     
  4.  
    def host_type():
  5.  
    run('uname -s')

启动

  1.  
    itcast@ubuntu:~/tmp/fab$ fab -H 127.0.0.1 host_type
  2.  
    [127.0.0.1] Executing task 'host_type'
  3.  
    [127.0.0.1] run: uname -s
  4.  
    [127.0.0.1] Login password for 'itcast':
  5.  
    [127.0.0.1] out: Linux
  6.  
    [127.0.0.1] out:
  7.  
     
  8.  
     
  9.  
    Done.
  10.  
    Disconnecting from 127.0.0.1... done.
  11.  
    itcast@ubuntu:~/tmp/fab$ fab -H 127.0.0.1 host_type
  12.  
    [127.0.0.1] Executing task 'host_type'
  13.  
    [127.0.0.1] run: uname -s
  14.  
    [127.0.0.1] Login password for 'itcast':
  15.  
    [127.0.0.1] out: Linux
  16.  
    [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:动态获取远程目录列表

  1.  
    from fabric.api import *
  2.  
     
  3.  
    env.hosts=['192.168.17.192', '192.168.17.193']
  4.  
    #env.password='python'
  5.  
    env.passwords = {
  6.  
    'itcast@192.168.17.192:22':'python',
  7.  
    'itcast@192.168.17.193:22':'python',
  8.  
    }
  9.  
     
  10.  
    @runs_once
  11.  
    def input_raw():
  12.  
    return prompt("please input directory name:", default="/home")
  13.  
     
  14.  
    def workask(dirname):
  15.  
    run('ls -l ' + dirname)
  16.  
     
  17.  
    @task
  18.  
    def go():
  19.  
    print('start ...')
  20.  
    getdirname = input_raw()
  21.  
    workask(getdirname)
  22.  
    print('end ...')

示例2:上传文件并执行

  1.  
    from fabric.api import *
  2.  
     
  3.  
    env.user = 'itcast'
  4.  
    env.hosts = ['192.168.17.192', '192.168.17.193']
  5.  
    env.password = 'python'
  6.  
     
  7.  
    @task
  8.  
    @runs_once
  9.  
    def tar_task():
  10.  
    with lcd('/home/itcast/testdemo'):
  11.  
    local('tar zcvf demo.tar.gz demo.py')
  12.  
     
  13.  
    @task
  14.  
    def put_task():
  15.  
    run('mkdir -p /home/itcast/testdemo')
  16.  
    with cd('/home/itcast/testdemo'):
  17.  
    put('/home/itcast/testdemo/demo.tar.gz', '/home/itcast/testdemo/demo.tar.gz')
  18.  
     
  19.  
    @task
  20.  
    def check_task():
  21.  
    lmd5 = local('md5sum /home/itcast/testdemo/demo.tar.gz', capture=True).split(' ')[0]
  22.  
    rmd5 = run('md5sum /home/itcast/testdemo/demo.tar.gz').split(' ')[0]
  23.  
    if lmd5 == rmd5:
  24.  
    print('OK ...')
  25.  
    else:
  26.  
    print('ERROR ...')
  27.  
     
  28.  
    @task
  29.  
    def run_task():
  30.  
    with cd('/home/itcast/testdemo'):
  31.  
    run('tar zxvf demo.tar.gz')
  32.  
    run('python demo.py')
  33.  
     
  34.  
    @task
  35.  
    def go():
  36.  
    tar_task()
  37.  
    put_task()
  38.  
    check_task()
  39.  
    run_task()

代码自动化部署

  1.  
    from fabric.api import *
  2.  
     
  3.  
    env.user = 'itcast'
  4.  
    env.hosts = ['192.168.17.192', '192.168.17.193']
  5.  
    env.password = 'python'
  6.  
     
  7.  
    @runs_once
  8.  
    @task
  9.  
    def local_update():
  10.  
    with lcd("/home/itcast/tmp/itcasthello"):
  11.  
    local("git add -A")
  12.  
    local("git commit -m 'update'")
  13.  
    local("git pull origin master")
  14.  
    local("git push origin master")
  15.  
     
  16.  
     
  17.  
    @task
  18.  
    def remote_update():
  19.  
    with cd("/home/itcast/tmp/itcasthello"):
  20.  
    run("git checkout master")
  21.  
    run("git pull origin master")
  22.  
     
  23.  
    @task
  24.  
    def deploy():
  25.  
    local_update()
  26.  
    remote_update()
 

Python学习笔记—自动化部署【新手必学】的更多相关文章

  1. Python基础语法总结【新手必学】

      前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:weixin_45189038直接上知识点: 1. 注释 单行注释: ...

  2. Python自定义包引入【新手必学】

    前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:sys_song python中的Module是比较重要的概念.常见的情 ...

  3. Python学习零基础<入门必学>

    1. 注释注释 是任何存在于 # 号右侧的文字,其主要用作写给程序读者看的笔记. 2. 字面常量一个字面常量(Literal Constants)的例子是诸如 5.1.23 这样的数字,或者是如 这是 ...

  4. Python开发五子棋游戏【新手必学】

    五子棋源码,原创代码,仅供 python 开源项目学习.目前电脑走法笨笨的,下一期版本会提高电脑算法ps:另外很多人在学习Python的过程中,往往因为遇问题解决不了或者没好的教程从而导致自己放弃,为 ...

  5. Python入门知识总结【新手必学】

    Python 基础学习输入和输出list 和 tuple条件判断循环dict 和 set感觉python这门语言用途较广,先熟悉下其语法.PS:另外很多人在学习Python的过程中,往往因为没有好的教 ...

  6. Python学习笔记(十三)

    Python学习笔记(十三): 模块 包 if name == main 软件目录结构规范 作业-ATM+购物商城程序 1. 模块 1. 模块导入方法 import 语句 import module1 ...

  7. Python 学习笔记 - 不断更新!

    Python 学习笔记 太久不写python,已经忘记以前学习的时候遇到了那些坑坑洼洼的地方了,开个帖子来记录一下,以供日后查阅. 摘要:一些报错:为啥Python没有自增 ++ 和自减 --: 0x ...

  8. 近期Python学习笔记

    近期Python 学习笔记--一篇文入门python 作者:Pleiades_Antares(www.cnblogs.com/irischen) 写在前面的话 想学Python已经许久,一年多以前(应 ...

  9. Deep learning with Python 学习笔记(10)

    生成式深度学习 机器学习模型能够对图像.音乐和故事的统计潜在空间(latent space)进行学习,然后从这个空间中采样(sample),创造出与模型在训练数据中所见到的艺术作品具有相似特征的新作品 ...

随机推荐

  1. [ASP.NET Core 3框架揭秘] 文件系统[1]:抽象的“文件系统”

    ASP.NET Core应用 具有很多读取文件的场景,比如配置文件.静态Web资源文件(比如CSS.JavaScript和图片文件等)以及MVC应用的View文件,甚至是直接编译到程序集中的内嵌资源文 ...

  2. css字体图标的制作

    我介绍的这个办法是直接在 "阿里巴巴图标库"中制作的,方便快捷 1. 首先到 "阿里巴巴图标库"中找到你想要的图片,然后选择加入购物车 接着我们点击右上角的购物 ...

  3. VS安装

    1. 只更改工作负载和单个组件 工作负载:我只勾选3个需要的 单个组件:  勾选  .NET 下Framework   别的不用改 2.点击安装,安装完成重启

  4. Java描述设计模式(21):状态模式

    本文源码:GitHub·点这里 || GitEE·点这里 一.生活场景 1.场景描述 变色龙是爬行动物,是非常奇特的动物,它有适于树栖生活的种种特征和行为,身体也会随着环境的变化而变化出适应环境的颜色 ...

  5. gitbook怎么操作

    首先我先说一下什么是GitBook,它和Git没半毛钱关系,定义如下: GitBook 是一个基于 Node.js 的命令行工具,支持 Markdown 和 AsciiDoc 两种语法格式,可以输出 ...

  6. Alibaba Nacos 学习(五):K8S Nacos搭建,使用nfs

    Alibaba Nacos 学习(一):Nacos介绍与安装 Alibaba Nacos 学习(二):Spring Cloud Nacos Config Alibaba Nacos 学习(三):Spr ...

  7. 学习PHP框架只停留在会用层面,职业生涯肯定走不远!

    工作这么多年,也面试过很多PHP工程师,我发现很多PHP工程师只停留在使用框架的层面,然而对框架底层根本没有深入去了解,那么这就会给自己的职业生涯带来一定的瓶颈,当遇到问题的时候你就无从下手,不知道如 ...

  8. 剖析nsq消息队列目录

    剖析nsq消息队列(一) 简介及去中心化实现原理 剖析nsq消息队列(二) 去中心化源码解析 剖析nsq消息队列(三) 消息传输的可靠性和持久化[一] 剖析nsq消息队列(三) 消息传输的可靠性和持久 ...

  9. html基础——div/span

    div是一个块标签/盒子标签,单独占据一行 span不会占据一块,一般是用来修改某几个文字的格式 比如一行字,需要将每一句的首字母大写,就可以使用span标签 如果是要将一个段落的字加样式,两个都可以 ...

  10. RobotFramework自动化测试框架-Selenium Web自动化(三)关于在RobotFramework中如何使用Selenium很全的总结(下)

    本文紧接着RobotFramework自动化测试框架-Selenium Web自动化(二)关于在RobotFramework中如何使用Selenium很全的总结(上)继续分享RobotFramewor ...