在公司经常要做测试环境的升级、备份、维护;升级后台的应用,不可避免要进行数据库的升级与备份,花了一个上午琢磨了一个脚本分享给大家。

ToB的业务,在做环境维护的时候,有初始化环境和增量升级的环境,在测试阶段,几乎每轮都会动数据库脚本,那么测试环境每轮都需要进行数据库的升级维护

对应业务,基本上会出现以下三种场景:

1、初始化环境,在业务上对应新的B端客户需要安装系统

  需要将数据库删除以后重建(必须要这么做,否则可能会出现上一轮的初始化脚本中用到的表,这一轮脚本中删除了,如果不删库重建,可能会存在冗余的表)

2、升级环境,业务上对应现有客户,需要进行系统升级,需执行增量脚本

  不论是测试环境还是线上环境,在升级执行之前都需要将数据库进行备份,防止升级失败需要回滚

3、升级环境(非首次),业务上仅会在测试环境上出现,如第一轮测试以后,升级脚本有更新了,在第二轮测试前,需要将数据库恢复到升级之前,再进行升级

设计思路:

执行脚本,需要传入4个参数,

第一个参数是sql脚本名称,因为每轮升级时,名称都可能不一样

第二个参数是要做升级或者初始化的数据库的名称

第三个参数是升级标识,

第四个参数是数据库备份的文件版本标识,例如升级前的版本是1.0.1,升级后的版本是1.0.2,那么将1.0.1传入,这样可以标识每次备份的文件版本

# coding=utf-8
import MySQLdb
import sys,os
from subprocess import Popen,PIPE db_file=sys.argv[1]
db_name = sys.argv[2]
update_flag = sys.argv[3]
#upadte_flag是升级表示,为1:表示是初始化环境,只需要删除数据库实例,并重建 2:首次进行升级,需要备份数据库 3:非首次升级,需要将数据库先进行回滚再升级
db_back_file_version = sys.argv[4]
db_back_path = '/home/DB'
db_host = 'localhost'
db_port = 3306
db_user = 'root'
db_passwd = 'password'
file_name = db_back_path+"/"+db_name+'_'+db_back_file_version+'.sql' if not os.path.exists(db_file):
print('升级脚本不存在,请检查') #如果备份文件存在,重命名
if os.path.exists(file_name):
os.rename(file_name,file_name+'bak') #如果是首次执行数据库升级,先备份
if update_flag == "2":
print('开始备份数据库…………………………')
dumpcmd = "mysqldump -u" + db_user + " -p" +db_passwd+" -h"+db_host+ " -R " + db_name + " > " + file_name
os.system(dumpcmd) conn = MySQLdb.connect(host=db_host,port=db_port,user=db_user,passwd=db_passwd,db=db_name)
c = conn.cursor()
process = Popen('mysql -u %s -h%s -p%s %s' %(db_user,db_host,db_passwd,db_name),stdout=PIPE, stdin=PIPE, shell=True)
if update_flag == "1":
c.execute('Drop database %s' %db_name)
c.execute('create database %s' %db_name)
c.execute('use %s' %db_name)
output = process.communicate('source '+db_file)
elif update_flag == "2":
c.execute('use %s' %db_name)
output = process.communicate('source '+db_file)
elif update_flag == "3":
c.execute('Drop database %s' %db_name)
c.execute('create database %s' %db_name)
c.execute('use %s' %db_name)
print('开始恢复数据库并升级数据库')
cmd = 'source '+file_name +';'+'source '+db_back_path+'/'+db_file+';'
output = process.communicate(cmd) c.close()
print('run success')

有问题欢迎大家拍砖,还有很大优化的空间

python脚本--mysql数据库升级、备份的更多相关文章

  1. mysql数据库分库备份脚本

    mysql数据库分库备份脚本 版本1 for dbname in `mysql -uroot -poldboy123 -e "show databases;" |grep -Evi ...

  2. 企业级mysql数据库完全备份、增量备份脚本

    企业完全备份脚本 [root@client ~]# vim /opt/mysql_bak_wanbei.sh #!/bin/bash #MySQL数据库完全备份脚本 #设置登录变量 MY_USER=& ...

  3. Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁

    Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁 一丶安装 pip install PyMySQL 二丶pymysql连接数据库 ### 语法: ...

  4. 使用python操作mysql数据库

    这是我之前使用mysql时用到的一些库及开发的工具,这里记录下,也方便我查阅. python版本: 2.7.13 mysql版本: 5.5.36 几个python库 1.mysql-connector ...

  5. 【Python】使用python操作mysql数据库

    这是我之前使用mysql时用到的一些库及开发的工具,这里记录下,也方便我查阅. python版本: 2.7.13 mysql版本: 5.5.36 几个python库 1.mysql-connector ...

  6. mysql安装和简要操作命令+python基本操作mysql数据库

    mysql数据库是一种关系型数据库管理系统.  一. windows平台安装Mysql数据库. Mysql数据库官网 :https://dev.mysql.com/downloads/windows/ ...

  7. mysqldump常用于MySQL数据库逻辑备份

    mysqldump常用于MySQL数据库逻辑备份. 1.各种用法说明 A. 最简单的用法: mysqldump -uroot -pPassword [database name] > [dump ...

  8. [知了堂学习笔记]_Java代码实现MySQL数据库的备份与还原

    通常在MySQL数据库的备份和恢复的时候,多是采用在cmd中执行mysql命令来实现. 例如: mysqldump -h127.0.0.1 -uroot -ppass test > d:/tes ...

  9. 使用percona-xtrabackup工具对mysql数据库的备份方案

    使用percona-xtrabackup工具对mysql数据库的备份方案 需要备份mysql的主机 172.16.155.23存放备份mysql的主机 172.16.155.22 目的:将155.23 ...

随机推荐

  1. Html,CSS和盒子

    Html指超文本标记语言(HyperText Markup Language)是一种用于创建网页的标准标记语言. CSS 指层叠样式表 (Cascading Style Sheets),样式定义如何显 ...

  2. MongoDB启动报错 32-bit servers don't have journaling enabled by default. Please use --journal if you want durability. 【转】

    之前MongoDB启动的时候是蛮正常的,不知道后来启动报错了,就把粘贴出来查询了.最后才知道是由于自己不正常的关闭导致的这个情况. --摘录:MongoDB非正常关闭后修复记录 mongod没有后台执 ...

  3. MVC EF 移除建表时自动加上s的复数形式

    移除建表时自动加上s的复数形式 public class DBContext : DbContext { public DBContext() : base("name=DBContext& ...

  4. 转载:原来JavaScript的闭包是这么回事!

    相关阅读:https://www.itcodemonkey.com/article/8565.html

  5. 哈尔滨工程大学第十四届程序设计竞赛(同步赛)F 小帆帆走迷宫(dp)

    题目描述 小帆帆被困在一个 NxN 的方格矩阵迷宫,每个格子中都有一个整数 A[i][j].小帆帆从迷宫起点(左上角)格子 A[1][1]开始走,每一步可以向右或向下移动,目标是移动到迷宫的出口右下角 ...

  6. CF1155F Delivery Oligopoly

    题意:给定简单无向图,求一个最小的边集使得这些点是边双,输出方案.n <= 14 解:考虑一个边双肯定是一条一条的链拼起来的.于是每次枚举一条链加上去就行了. 设fs表示点集s形成边双的最小边数 ...

  7. php禁止某ip或ip地址段访问的方法(转载)

    <?php include("banIP.php");?> 禁用单个ip如下:<?php //禁用ip地址 $ip=$_SERVER["REMOTE_A ...

  8. 给centos装图形界面 widowsx

    检查Linux系统是否能够联网.   执行命令 yum -y groupinstall Desktop   等上面的命令执行完后,再执行这条命令 yum -y groupinstall "X ...

  9. Jira与Confluence集成、授权信息查看和问题汇总

    上一篇文章详细阐述了jira和confluence的安装部署和相关配置的操作记录,也介绍了两者之间其中一种集成方式:下面介绍另外的集成方式. 安装部署jira和confluence的顺序是,先安装ji ...

  10. Linux命令_sed

    1.替换(将"xxx"替换成"yyy") 现有文件pets.txt 要将其中的"my"替换为"your",可以这样替换, ...