python脚本按表备份MySQL数据库

脚本功能:

1.自动创建备份目录

2.自动备份数据库的每个表,并压缩

3.备份结果,邮件通知联系人

4.脚本内容

#!/usr/bin/env  python
# --*-- coding:UTF-8 --*--
# Create by JIANGLEI.YU on 2016/04/21
# 多表自动备份ok。发送邮件失败。
import  MySQLdb
import  sys
import  os
import  datetime
import  smtplib
from    email.mime.text   import MIMEText
import  sys

# Define Mysql Environments
Hostname=‘192.168.0.141‘
Username=‘root‘
Password=‘123456‘
Database=‘virtual‘
MYSQLDUMP=‘/usr/bin/mysqldump‘
GZIP=‘/usr/bin/gzip‘
timestamp=datetime.datetime.now().strftime("%Y%m%d%H%M%S")
Destination_dir=‘/home/bak/tables/‘ + timestamp + ‘/‘

# Define Smtp Environments
Host=‘smtp.exmail.qq.com‘
Port=25
sender=‘[email protected]‘
Pass=‘123456‘
recivers=‘[email protected]‘
def main():
if os.path.exists(Destination_dir) == False:
os.makedirs(Destination_dir)
db_table_backup()
else:
db_table_backup()
def email():
try:
server= smtplib.SMTP()
server.connect(Host,Port)
server.login(sender,Pass)
server.sendmail(sender,recivers,msg.as_string())
except Exception,e:
print e
print "邮件发送失败!"
def backup_failed():
global msg
msg = MIMEText(‘数据库单表备份失败‘)
msg[‘subject‘] = ‘数据库单表备份失败‘
msg[‘From‘] = sender
msg[‘To‘] = recivers
email()
sys.exit(2)
def backup_sucess():
global msg 
msg = MIMEText((‘数据库单表备份成功,共备份%d张表,共用时%.2f分钟.‘) % (tables_count,backup_period) ,  ‘plain‘,‘utf-8‘ ) 
msg[‘subject‘] = ‘数据库单表备份成功‘  
msg[‘From‘] = sender
msg[‘To‘] = recivers
email()
def db_table_backup():
start_time=datetime.datetime.now()
try:
db = MySQLdb.connect(Hostname,Username,Password,Database,connect_timeout=2)
cursor = db.cursor()
except Exception, e:
# print e
print "连接数据库失败"
backup_failed()
cursor.execute(‘show tables‘)
f = cursor.fetchall()
list_status = []
for table in f:
# print table
for i in table:
MYSQLDUMP_CMD = MYSQLDUMP + ‘ -h‘ + Hostname + ‘ -u‘ + Username + ‘ -p‘ + Password + ‘ ‘ +  Database + ‘ ‘ + i + ‘ ‘ + ‘| ‘ + GZIP + ‘ >‘ + Destination_dir + Database + ‘-‘ + timestamp+ ‘.‘ + i + ‘.‘ + ‘sql.gz‘
result = os.system(MYSQLDUMP_CMD)
list_status.append(result)
global tables_count
tables_count = len(list_status)
list_test=[0]
j = set(list_status).issubset(set(list_test))
if j == True:
end_time=datetime.datetime.now()
global backup_period
backup_period = ((end_time - start_time).seconds)/60.0
backup_sucess()
else:
backup_failed()
cursor.close()
db.close()
if __name__ ==  ‘__main__‘:
main()
时间: 2024-10-06 00:38:11

python脚本按表备份MySQL数据库的相关文章

使用shell脚本实现自动备份MySQL数据库

192.168.1.2服务器对192.168.1.1服务器上的MySQL数据库进行备份. 必须满足的条件: 1.在192.168.1.1服务器上创建专门用来备份的数据库账号,并赋予相应的权限: mysql> grant select,lock tables on *.* to 'operator'@'192.168.%.%' identified by '123456'; #备份数据库需要账号具有查看表和锁定表的权限 2.在192.168.1.2服务器上使用该账号进行手工备份,测试是否可以备份成

python脚本——一种连接mysql数据库的方法(取回数据为list非tuple格式)并将数据写入TXT

python连接数据库有几种方法,但是对于从数据库取回的数据格式却有些不同,取回为tuple格式的数据处理起来比较麻烦,接下来介绍一种取回为list格式的连接方法,list格式数据处理和使用起来比较方便. #!/usr/bin/python# -*- coding: utf-8 -*-#!/usr/bin/env pythonimport MySQLdbfrom commands import getstatusoutput, getoutputimport sys reload(sys)sys

[转]一个备份MySQL数据库的简单Shell脚本

本文翻译自 iSystemAdmin 的 <A Simple Shell Script to Backup MySQL Database> Shell脚本是我们写不同类型命令的一种脚本,这些命令在这一个文件中就可以执行.我们也可以逐一敲入命令手动执行.如果我们要使用shell脚本就必须在一开始把这些命令写到一个文本文件中,以后就可以随意反复运行这些命令了. 我首先要在本文带给你的是完整脚本.后面会对该脚本做说明.我假定你已经知道shell scripting. mysqldump和cronta

Linux Shell脚本之利用mysqldump备份MySQL数据库(详细注解)

设计该脚本的一些设计.编写考虑: 该脚本适用于编译安装mysql和通过yum或apt-get等安装方式 该脚本可以反复执行,不会重复覆盖数据 可增加,删除N天前的备份以节省磁盘空间 充分利用mysqldump的自带锁表功能.刷新日志.复制等功能 利用mysqldump命令备份MySQL数据库的脚本(不带注释版,适合生产环境使用) #!/bin/bash MYSQLDBUSERNAME=root MYSQLDBPASSWORD=password MYSQBASEDIR=/usr/local/mys

Shell脚本-----自动备份Mysql数据库

脚本的整体思路 1.定义需要的变量 2.利用for循环备份需要备份的库,并以库名-当天日期.sql命名,并记录相关日志 3.建立备份当天的日期的目录,向备份的Sql文件移动到该目录 4.压缩打包该目录,以节省空间,打包成功后删除该目录 5.备份目录只备份七天的数据库,第八天删除第一天的备份,目录只会存在连续七天的备份文件 6.查找备份目录下的.log日志文件,超过七天的删除 #!/bin/bash mysql_bin=/usr/local/tdoa/mysql/bin/mysqldump use

Linux下定时备份MySQL数据库的Shell脚本

Linux下定时备份MySQL数据库的Shell脚本 对任何一个已经上线的网站站点来说,数据备份都是必须的.无论版本更新还是服务器迁移,备份数据的重要性不言而喻.人工备份数据的方式不单耗费大量时间和精力,还灰常不专业的说.于是,有了下面这段脚本的出现.参考了网上的很多教程,外加自己的测试,以下脚本经测试可用.#!/bin/bash#Shell Command For Backup MySQL Database Everyday Automatically By Crontab#Author :

定时备份mysql数据库的shell脚本

最近项目需要定时备份mysql数据库的数据,根据需求写了一份定时备份mysql数据库的脚本. -h mysql的地址  默认为localhost -P 端口号  默认为3306 -u 用户  默认为root -p 密码 默认为123456 -f  备份存放地址  默认为 /bak 下面 -n 指定数据库  默认为所有数据库(除开mysql系统自带数据库) #!/bin/bash now=`date "+%Y-%m-%d_%H:%M:%S" ` echo "==========

如何在生产环境下实现每天自动备份mysql数据库

1.描述 我相信很多朋友在工作都都会有这种需求,老板或领导让你每天都要备份mysql数据库,你该如何实现呢,是每天到一定的时间在服务器上敲一遍mysql的备份命令,还是想写个脚本,定时定点的自动备份呢?我相信大家都想让它自动备份,接下来我通"shell脚本+定时任务"的方式来实现自动备份mysql数据库. 2.环境 备份路径:/data/mysqlbak/ 备份脚本:/data/mysqlbak/mysqlbak.sh 备份时间:每天23:59备份 备份要求:比如备份的数据只保留1周

简单备份MySQL数据库

本文链接:https://blog.inchm.cn/default/44.html 说是备份MySQL数据库,其实也适用于它的胞弟MariaDB. 备份 创建备份脚本 创建一个备份脚本: #!/bin/sh #把要备份的数据库dump出来,压缩后存放.路径不要有空格 mysqldump -uusername -ppassword your_database_name | gzip > /path/of/backup/directory/your_database_name+_%Y-%m-%d_