批量备份,删除MySQL表(python脚本)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

                                       批量备份,删除MySQL表(python脚本)

#!/usr/bin/env python
#coding=utf-8

#本脚本主要用来批量删除以RBCN开头命名,以数字结尾的表。先找出此类表,备份,远程拷贝(由于本主机的空间不足),删除本地备份文件,删除库表。
#引入MySQL模块
import MySQLdb
#引入re(正则表达式)模块
import re
#引入os模块(执行系统命令)
import os
#引入pexpect模块(可以实现通过ssh,ftp等程序自动交互)
import pexpect

#指定连接MySQL实例的账户,密码,字符集,及备份目录
User = 'root'
Passwd = '123456'
Db = 'db_test'
Charset = 'gbk'
Cmd = '/usr/bin/mysqldump'
Path = '/tmp/'

#指定关于远程拷贝的相关主机,密码,目录等
Scp_Path = '/usr/bin/scp'
Remote_Host = '172.31.x.x'
Remote_User = 'root'
Remote_Passwd = '123456'
Remote_Path = '/mnt/data/mysqlbackup/table_backup/'

#创建一个连接对象
con = MySQLdb.connect(host="localhost", port=3306, user="root", passwd="123456", db="db_test")
#创建游标,所有的查询,都在连接con的一个模块cursor上面运行的
cursor = con.cursor()
#查看数据库中存在的表名
sql = "SHOW TABLES"
cursor.execute(sql)
#从游标中取出所有记录放入一个元组序列
results = cursor.fetchall()

#通过for循环取出元组每个元素(其还是元组)
for result in results:
    #取出每个元素的值,引用re模块的match方法做匹配,其中\A代表匹配的开始位置,\Z代表匹配的末尾位置,\d代表任意数字。
    m2 = re.match(r"\ARBCN.*\d\Z", result[0])
    #判断m2的值为真,则进行以下处理(也就是匹配到的表)
    if m2:
       print result[0]
       #取出表名
       Table_name = result[0]
       #定义备份此表
       Backup_Cmd = "%s --default-character-set=%s -u%s -p%s %s %s > %s%s" %(Cmd,Charset,User,Passwd,Db,Table_name,Path,Table_name)
       #执行备份,判断如果备份成功,做如下处理
       if os.system(Backup_Cmd) == 0:
          print 'Successful backup',result[0]
          #定义远程拷贝
          Scp_Cmd = "%s %s%s 
%s@%s:%s" %(Scp_Path,Path,Table_name,Remote_User,Remote_Host,Remote_Path)
          #调用pexpect的spawn模块,执行Scp_Cmd命令
          scp = pexpect.spawn(Scp_Cmd)
          #密码验证
          scp.sendline('Remote_Passwd')
          scp.read()
          scp.close()
          #删除本地备份文件
          re_file = "%s%s" %(Path,Table_name)
          os.remove(re_file)
          #删除数据库中此表 
          sql2 = "DROP TABLE %s" %(Table_name)
          cursor.execute(sql2)        
       else:
          print 'Failed'

con.close()

#author:lyk
#time:2013/07/23
#added:此脚本并不完美,如ssh的timeout时间判断,验证远程主机是否已存在备份文件,md5值验证等。本环境为线上内网,所以,,,










本文转自 kuchuli 51CTO博客,原文链接:http://blog.51cto.com/lgdvsehome/1255172,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
3月前
|
JSON 算法 API
深度分析小红书城API接口,用Python脚本实现
小红书作为以UGC内容为核心的生活方式平台,其非官方API主要通过移动端抓包解析获得,涵盖内容推荐、搜索、笔记详情、用户信息和互动操作等功能。本文分析了其接口体系、认证机制及请求规范,并提供基于Python的调用框架,涉及签名生成、登录态管理与数据解析。需注意非官方接口存在稳定性与合规风险,使用时应遵守平台协议及法律法规。
|
3月前
|
JSON API 数据安全/隐私保护
【干货满满】分享微店API接口到手价,用python脚本实现
微店作为知名社交电商平台,其开放平台提供商品查询、订单管理等API接口。本文介绍如何通过微店API获取商品到手价(含优惠、券等),涵盖认证机制、Python实现及关键说明。
|
3月前
|
JSON API 数据格式
深度分析大麦网API接口,用Python脚本实现
大麦网为国内领先演出票务平台,提供演唱会、话剧、体育赛事等票务服务。本文基于抓包分析其非官方接口,并提供Python调用方案,涵盖演出列表查询、详情获取及城市列表获取。需注意非官方接口存在稳定性风险,使用时应遵守平台规则,控制请求频率,防范封禁与法律风险。适用于个人学习、演出信息监控等场景。
|
3月前
|
存储 关系型数据库 MySQL
在CentOS 8.x上安装Percona Xtrabackup工具备份MySQL数据步骤。
以上就是在CentOS8.x上通过Perconaxtabbackup工具对Mysql进行高效率、高可靠性、无锁定影响地实现在线快速全量及增加式数据库资料保存与恢复流程。通过以上流程可以有效地将Mysql相关资料按需求完成定期或不定期地保存与灾难恢复需求。
332 10
|
3月前
|
JSON API 开发者
深度分析阿里妈妈API接口,用Python脚本实现
阿里妈妈是阿里巴巴旗下营销平台,提供淘宝联盟、直通车等服务,支持推广位管理、商品查询等API功能。本文详解其API调用方法,重点实现商品推广信息(佣金、优惠券)获取,并提供Python实现方案。
|
3月前
|
JSON API 数据安全/隐私保护
深度分析虾皮城API接口,用Python脚本实现
虾皮开放平台提供丰富的API接口,支持商品管理、订单处理及促销信息查询等功能。本文详解API认证机制与调用方法,基于Python实现商品价格及到手价获取方案,适用于电商数据分析与运营。
|
3月前
|
JSON API 数据安全/隐私保护
【干货满满】分享拼多多API接口到手价,用python脚本实现
拼多多开放平台提供商品价格查询API,通过“pdd.ddk.goods.detail”接口可获取商品基础价、优惠券、拼团价等信息。结合client_id、client_secret及签名机制实现身份认证,支持推广位ID获取专属优惠。本文提供完整Python实现,涵盖签名生成、接口调用与价格解析逻辑,适用于比价工具、导购平台等场景。
|
3月前
|
API 数据安全/隐私保护 开发者
深度分析苏宁API接口,用Python脚本实现
深度分析苏宁API接口,用Python脚本实现
|
3月前
|
前端开发 Shell API
深度分析58同城API接口,用Python脚本实现
58同城为国内知名分类信息平台,涵盖房产、招聘、二手车等多领域。本文基于网页抓包与解析,分享其非官方接口的Python实现方案,分析核心接口特性与反爬应对策略,适用于数据学习与信息聚合。注意:非官方接口存在风险,使用需遵守平台规则。
|
3月前
|
JSON API 数据安全/隐私保护
【干货满满】分享京东API接口到手价,用python脚本实现
淘宝开放平台提供丰富API,通过商品详情接口与淘宝联盟接口,可获取含优惠券、满减后的商品到手价。本文介绍基于Python的实现方案,涵盖签名生成、接口调用、价格解析及错误处理,适用于比价工具、导购平台等场景。

推荐镜像

更多