备份

新建一个脚本/root/backup.py,内容如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
'''
脚本作者:昨夜星辰
脚本作用:配合crond服务实现自定义周期备份MySQL数据库(使用innobackupex进行备份)
创建日期:2016年9月22日
''' import os
import datetime
import subprocess # MySQL服务root用户的密码
password = 'test' # 用于存放备份的目录
path = '/backup' # 备份周期(单位:天)
cycle = 30 # 获取当天的日期
today = datetime.date.today() # 获取昨天的日期
yesterday = today + datetime.timedelta(days=-1) # 判断备份目录下的文件数是否等于备份周期,如果是就清空备份目录。
if len(os.listdir(path)) == cycle:
os.system('rm -rf %s/*' % path) # 判断备份目录下是否存在以昨天日期命名的目录,如果是就进行增量备份,否则就进行完整备份。
if os.path.isdir('%s/%s' % (path, yesterday)):
cmd = 'innobackupex --password=%s --incremental %s --incremental-basedir=%s/%s --no-timestamp' % (password, path, path, yesterday)
else:
cmd = 'innobackupex --password=%s %s/%s --no-timestamp' % (password, path, today) # 执行备份命令
subprocess.call(cmd, shell=True, stderr=subprocess.PIPE)

读者请注意根据自身实际情况修改脚本中的path、password、cycle变量。

执行下面的命令进入crontab的编辑模式:

crontab -e

新增以下内容:

# 每天凌晨2点自动执行数据库备份脚本
0 2 * * * python /root/python &> /dev/null

还原

# -*- coding: utf-8 -*-
'''
脚本作者:昨夜星辰
脚本作用:使用innobackupex命令还原MySQL服务
创建日期:2016年9月22日
''' import os
import subprocess # 用于存放备份的目录
path1 = '/backup' # MySQL服务的数据目录
path2 = '/wwwroot/mysql' # 获取备份目录下的文件并排序
d_list = sorted(os.listdir(path1)) # 警告信息
alert_message = '''
警告!!!
请检查脚本中的path1、path2变量是否配置正确。
还原操作需要停止MySQL服务并清空数据目录,在生产环境中操作需谨慎!
在硬盘空间足够的前提下,建议重命名数据目录,然后再新建一个同名的数据目录。 比如您的数据目录是/data,那么你可以这么做:
service mysqld stop
mv /data /data_bak
mkdir /data
'''
print alert_message # 询问用户是否继续
while True:
answer = raw_input('准备好后就输入“Y”继续,或者输入“N”退出:')
if answer == 'Y':
break
elif answer == 'N':
exit(0)
else:
print '输入有误,请重新输入!' # 打印日期列表的序号和日期
for i in range(len(d_list)):
print '%d. %s' % (i, d_list[i]) # 询问用户需要还原的日期的序号,如果用户输错了,就提示并要求用户重新输入。
while True:
try:
SN = int(raw_input('请输入你想还原的日期对应的序号:'))
if SN not in range(len(d_list)):
print '输入有误,请重新输入!'
elif not os.path.isdir('%s/%s' % (path1, d_list[SN])):
print '输入有误,请重新输入!'
else:
break
except ValueError:
print '输入有误,请重新输入!' # 停止MySQL服务
os.popen('service mysqld stop') # 清空MySQL服务的数据目录
os.popen('rm -rf %s/*' % path2) print # 如果SN的值为真,那就说明用户选择了增量备份,需要将所有增量备份按顺序合并到完整备份中。
if SN:
print '开始合并所有增量备份到完整备份中...'
for i in range(SN + 1):
print '正在合并%s的数据...' % d_list[i]
if i == 0:
cmd = 'innobackupex --apply-log --redo-only %s/%s' % (path1, d_list[0])
elif i == SN:
cmd = 'innobackupex --apply-log %s/%s --incremental-dir=%s/%s' % (path1, d_list[0], path1, d_list[i])
else:
cmd = 'innobackupex --apply-log --redo-only %s/%s --incremental-dir=%s/%s' % (path1, d_list[0], path1, d_list[i])
subprocess.call(cmd, shell=True, stderr=subprocess.PIPE) print '正在回滚未提交的事务...'
# 回滚未提交的事务
cmd = 'innobackupex --apply-log %s/%s' % (path1, d_list[0])
subprocess.call(cmd, shell=True, stderr=subprocess.PIPE) print '开始还原...'
# 开始还原
cmd = 'innobackupex --copy-back %s/%s' % (path1, d_list[0])
subprocess.call(cmd, shell=True, stderr=subprocess.PIPE) # 变更MySQL数据目录的属主和数组
os.popen('chown -R mysql.mysql %s' % path2) # 启动MySQL服务
os.popen('service mysqld start') print '还原完毕!'

读者请注意根据自身实际情况修改脚本中的path1、path2变量。

配合crond服务实现自定义周期备份MySQL数据库(使用innobackupex进行备份)的更多相关文章

  1. ​学会用各种姿势备份MySQL数据库

    学会用各种姿势备份MySQL数据库 前言 为什么需要备份数据? 数据的备份类型 MySQL备份数据的方式 备份需要考虑的问题 设计合适的备份策略 实战演练 使用cp进行备份 使用mysqldump+复 ...

  2. centos6.5环境通过shell脚本备份php的web及mysql数据库并做远程备份容灾

    centos6.5环境通过shell脚本备份php的web及mysql数据库并做远程备份容灾 系统:centos6.5 1.创建脚本目录 mkdir -p /usr/local/sh/ 创建备份web ...

  3. Linux 每天自动备份mysql数据库的方法

    Linux 每天自动备份mysql数据库的方法 作者: 字体:[增加 减小] 类型:转载   linux下为了安全有时候需要自动备份mysql数据库,下面是具体的实现步骤.   /usr/bin为my ...

  4. 定时自动备份mysql数据库

    新建备份文件并赋予可以执行的权限 mkdir -p /home/mysql_backup/ touch /home/mysql_backup/mysql_backup.sh chmod 551 /ho ...

  5. Linux下自动备份MySQL数据库并上传到远程FTP服务器

    Linux下自动备份MySQL数据库并上传到远程FTP服务器且删除指定日期前的备份Shell脚本 说明:  1.备份MySQL数据库存放目录/var/lib/mysql下面的xshelldata数据库 ...

  6. 实现定时备份mysql数据库并把备份数据库邮件发送

    一.先来看备份mysql数据库的命令 1 mysqldump -u root --password=root --database abcDataBase > c:/abc_backup.sql ...

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

    Linux下定时备份MySQL数据库的Shell脚本   对任何一个已经上线的网站站点来说,数据备份都是必须的.无论版本更新还是服务器迁移,备份数据的重要性不言而喻.人工备份数据的方式不单耗费大量时间 ...

  8. 170208、用Navicat自动备份mysql数据库

    数据库备份很重要,很多服务器经常遭到黑客的恶意攻击,造成数据丢失,如果没有及时备份的话,后果不堪设想. 一:备份的目的: 做灾难恢复:对损坏的数据进行恢复和还原 需求改变:因需求改变而需要把数据还原到 ...

  9. 用Navicat自动备份mysql数据库

    以下文章转载自https://blog.csdn.net/u013628152/article/details/54909885,放在自己的博客园以供后面方便查询 —————————————————— ...

随机推荐

  1. .NET中的动态编译

    代码的动态编译并执行是一个.NET平台提供给我们的很强大的工具用以灵活扩展(当然是面对内部开发人员)复杂而无法估算的逻辑,并通过一些额外的代码来扩展我们已有 的应用程序.这在很大程度上给我们提供了另外 ...

  2. Python error: Unable to find vcvarsall.bat

    在安装一些Python模块时,大部分是cpython写的模块时会发生如下错误 error: Unable to find vcvarsall.bat.先前的一篇文章:在Windows上安装Scrapy ...

  3. HTML meta 头部的一些内容

    <meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable= ...

  4. 关于Windows2008服务器设置MIME后仍然无法播放MP4的解决方法

    最近遇到了一个非常邪门的故障,重新安装了Windows2008服务器后 Mp4无法正常播放: 整个互联网中关于设置MP4的方法基本都是教你如何在IIS中设置MIME 本文讨论的不是如何教你设置MIME ...

  5. 如何在Ubuntu下的VirtualBox虚拟机(Windows XP)里挂载/使用U盘 (转载)

    文章来源:http://www.codelast.com/ 在Ubuntu下安装了VirtualBox之后,如果你的虚拟机安装的是Windows XP系统,那么,你会发现,当你插上U盘时,无论你怎么折 ...

  6. BestCoder Round #90 A.Kblack loves flag(随机数生成种子)

    A.Kblack loves flag [题目链接]A.Kblack loves flag [题目类型]水题 &题意: kblack喜欢旗帜(flag),他的口袋里有无穷无尽的旗帜. 某天,k ...

  7. 序列最小最优化算法(SMO)-SVM的求解(续)

    在前一篇文章中,我们给出了感知器和逻辑回归的求解,还将SVM算法的求解推导到了最后一步,在这篇文章里面,我们将给出最后一步的求解.也就是我们接下来要介绍的序列最小最优化算法. 序列最小最优化算法(SM ...

  8. Linux添加主机路由

    Linux添加主机路由:参考:http://zhidao.baidu.com/link?url=50qQ232ZiJqq1iftHvBdPzZh-JlQGi1DZ8wvF-j9dvQYsKiNgc-6 ...

  9. HTML中让表单input等文本框为只读不可编辑的方法

    有时候,我们希望表单中的文本框是只读的,让用户不能修改其中的信息,如使<input type="text" name="input1" value=&qu ...

  10. 支持ASP.NET MVC

    ASP.NET MVC能很方便在后台返回JSON数据,所以与MiniUI进行数据交互非常简单. 1)后台处理: 在MVC控制器中,可以通过方法参数接收数据,也可以通过Request接收更复杂的数据对象 ...