python自动化部署代码_使用Python进行自动化部署

123031_4ylp_2772739.png

pexpect

Pexpect 是 Don Libes 的 Expect 语言的一个 Python 实现,是一个用来启动子程序,并使用正则表达式对程序输出做出特定响应,以此实现与其自动交互的 Python 模块。 Pexpect 的使用范围很广,可以用来实现与 ssh、ftp 、telnet 等程序的自动交互;可以用来自动复制软件安装包并在不同机器自动安装;还可以用来实现软件测试中与命令行交互的自动化。

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')

启动

lyt@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 'lyt':

[127.0.0.1] out: Linux

[127.0.0.1] out:

Done.

Disconnecting from 127.0.0.1... done.

lyt@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 'lyt':

[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/lyt/hello')

get : 从远程主机下载文件到本地,如:get('/home/python/world', '/home/lyt/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="199000"

env.passwords : 不同的主机不同的密码,如:env.passwords={'lyt@192.168.17.192:22':'199000', 'lyt@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 = {

'lyt@192.168.17.192:22':'python',

'lyt@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 = 'lyt'

env.hosts = ['192.168.17.192', '192.168.17.193']

env.password = 'python'

@task

@runs_once

def tar_task():

with lcd('/home/lyt/testdemo'):

local('tar zcvf demo.tar.gz demo.py')

@task

def put_task():

run('mkdir -p /home/lyt/testdemo')

with cd('/home/lyt/testdemo'):

put('/home/lyt/testdemo/demo.tar.gz', '/home/lyt/testdemo/demo.tar.gz')

@task

def check_task():

lmd5 = local('md5sum /home/lyt/testdemo/demo.tar.gz', capture=True).split(' ')[0]

rmd5 = run('md5sum /home/lyt/testdemo/demo.tar.gz').split(' ')[0]

if lmd5 == rmd5:

print('OK ...')

else:

print('ERROR ...')

@task

def run_task():

with cd('/home/lyt/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 = 'lyt'

env.hosts = ['192.168.17.192', '192.168.17.193']

env.password = 'python'

@runs_once

@task

def local_update():

with lcd("/home/lyt/tmp/lythello"):

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/lyt/tmp/lythello"):

run("git checkout master")

run("git pull origin master")

@task

def deploy():

local_update()

remote_update()

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python自动化部署使用Python编写脚本来实现应用程序的自动部署过程。通过编写脚本,可以简化和加快部署过程,提高开发效率。 Python自动化部署的具体步骤包括以下几个方面: 1. 环境准备:在部署服务器上安装必要的软件和依赖,例如Python解释器、虚拟环境管理工具、版本控制工具等。 2. 代码管理:使用版本控制工具(如Git)管理代码,并确保代码部署服务器上的代码保持同步。 3. 配置管理:将应用程序的配置信息(例如数据库连接、环境变量等)存储在配置文件中,并在部署过程中自动加载。 4. 虚拟环境管理:使用虚拟环境管理工具(如venv、virtualenv)创建独立的Python环境,以隔离不同应用程序之间的依赖关系。 5. 依赖管理:通过使用依赖管理工具(如pip、conda)安装和管理应用程序所需的第三方库和模块。 6. 构建和打包:根据需求,将应用程序打包成可执行文件、Docker镜像或其他形式的发布包。 7. 部署脚本编写:编写Python脚本,实现自动化部署的各个步骤,包括下载代码、安装依赖、配置环境等。 8. 自动化部署工具:使用自动化部署工具(如Fabric、Ansible、SaltStack)执行部署脚本,并提供一些额外功能,如批量部署部署回滚等。 通过Python自动化部署,可以简化部署过程,减少人工操作和错误,提高部署效率和一致性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值