• Python学习笔记—自动化部署【新手必学】


     

    目录

    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()
     
  • 相关阅读:
    朋友
    Music
    Rnadom Teams
    Bone Collector(01背包)
    Common Subsequence LCS
    Copying Books
    Equal Sum Sets
    Checker Challenge
    棋盘问题
    油田(Oil Deposits)
  • 原文地址:https://www.cnblogs.com/chengxuyuanaa/p/12013740.html
Copyright © 2020-2023  润新知