首页 数据库 mysql教程 Mysql开源备份工具Xtrabackup备份部署_MySQL

Mysql开源备份工具Xtrabackup备份部署_MySQL

Jun 01, 2016 pm 01:33 PM
在线 影响 替代品

bitsCN.com

Mysql开源备份工具Xtrabackup备份部署

 

  Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具InnoDB Hotbackup的一个很好的替代品。 

  Xtrabackup有两个主要的工具:xtrabackup、innobackupex 

  1、xtrabackup只能备份InnoDB和XtraDB两种数据表,而不能备份MyISAM数据表 

  2、innobackupex是参考了InnoDB Hotbackup的innoback脚本修改而来的.innobackupex是一个perl脚本封装,封装了xtrabackup。主要是为了方便的 同时备份InnoDB和MyISAM引擎的表,但在处理myisam时需要加一个读锁。并且加入了一些使用的选项。如slave-info可以记录备份恢 复后,作为slave需要的一些信息,根据这些信息,可以很方便的利用备份来重做slave。

  

  Xtrabackup下载地址:

   http://www.percona.com/downloads/XtraBackup/LATEST/binary/

  

  选择合适的版本,我这里选择binary。

  

  解压到/usr/src/目录,解压后目录名percona-xtrabackup-2.1.3,进入到bin目录,即可直接使用innobackupex命令

  # pwd

  /usr/src/percona-xtrabackup-2.1.3/bin

  # ls -l

  total 112396

  -rwxr-xr-x 1 root root   110738 Jun  7 11:43 innobackupex

  -rwxr-xr-x 1 root root   110738 Jun  7 11:43 innobackupex-1.5.1

  -rwxr-xr-x 1 root root  2211237 Jun  7 11:43 xbcrypt

  -rwxr-xr-x 1 root root  2285672 Jun  7 11:43 xbstream

  -rwxr-xr-x 1 root root 13033745 Jun  7 11:43 xtrabackup

  -rwxr-xr-x 1 root root 16333506 Jun  7 11:43 xtrabackup_55

  -rwxr-xr-x 1 root root 80988093 Jun  7 11:43 xtrabackup_56

  

  在开始使用的时候可能会报如下错误:

  sh: xtrabackup_55: command not found

  innobackupex: fatal error: no 'mysqld' group in MySQL options

 

 

  解决办法xtrabackup_55复制到/usr/bin下即可。

  # cp /usr/src/percona-xtrabackup-2.1.3/bin/xtrabackup_55 /usr/bin/

  

  

  建立mysql备份用户:

  mysql> GRANT RELOAD, LOCK TABLES, REPLICATION CLIENT ON *.* TO 'backupuser'@'localhost' identified by 'skEBfef5E2';

  mysql> FLUSH PRIVILEGES;

  

  备份脚本内容(每周一次全备,六次增量备份,保留2周的备份,并压缩):

   

[plain]

#!/bin/bash   

BEGINTIME=`date "%Y-%m-%d %H:%M:%S"`   

format_time=`date "%Y-%m-%d_%H:%M:%S"`   

week=`date %w`   

backupbin=/usr/src/percona-xtrabackup-2.1.3/bin   

backdir=/data/databasebak/bak   

file_cnf=/etc/my.cnf  

user_name=backupuser   

password="skEBfef5E2"  

db="db1 db2 db3 db4"  

out_log=$backdir/xtrabackup_log_$format_time   

time_cost=$backdir/xtrabackup_time.txt  

  

if [ -f "$backdir.lastlastlastweek.gz" ];then  

        rm -rf $backdir.lastlastweek.gz  

        mv $backdir.lastweek.gz $backdir.lastlastweek.gz  

fi  

  

if [ -d "$backdir/rec5" ];then   

        gzip -cr $backdir >$backdir.lastweek.gz  

        rm -rf $backdir            

        mkdir $backdir   

fi  

   

#full   

if [ ! -d "$backdir/full" ];then  

        echo "#####start full backup at $BEGINTIME to directory full" >>$time_cost  

         $backupbin/innobackupex --defaults-file=$file_cnf --no-timestamp --user=$user_name --password=$password --slave-info --databases="$db" $backdir/full 1> $out_log 2>&1  

         break;  

elif [ ! -d "$backdir/rec0" ];then   

        echo "#####start 0 incremental backup at $BEGINTIME to directory rec0" >>$time_cost   

        $backupbin/innobackupex --defaults-file=$file_cnf  --no-timestamp --user=$user_name --password=$password --slave-info --databases="$db" --incremental --增量-basedir=$backdir/full $backdir/rec0 1> $out_log 2>&1  

        中断;  

elif [ ! -d "$backdir/rec1" ];然后  

        echo "#####在 $BEGINTIME 开始 1 次增量备份到目录 rec1" >>$time_cost  

        $backupbin/ innobackupex --defaults-file=$file_cnf --no-timestamp --user=$user_name --password=$password --slave-info --databases="$db" --incremental --incremental-basedir=$backdir /rec0 $backdir/rec1 1> $out_log 2>&1  

         break;  

elif [ ! -d "$backdir/rec2" ];然后  

        echo "#####在 $BEGINTIME 开始 2 次增量备份到目录 rec2" >>$time_cost  

        $backupbin/ innobackupex --defaults-file=$file_cnf --no-timestamp --user=$user_name --password=$password --slave-info --databases="$db" --incremental --incremental-basedir=$backdir /rec1 $backdir/rec2 1> $out_log 2>&1  

         break;  

elif [ ! -d "$backdir/rec3" ];然后  

        echo "#####在 $BEGINTIME 开始 3 次增量备份到目录 rec3" >>$time_cost  

        $backupbin/ innobackupex --defaults-file=$file_cnf --no-timestamp --user=$user_name --password=$password --slave-info --databases="$db" --incremental --incremental-basedir=$backdir /rec2 $backdir/rec3 1> $out_log 2>&1  

         break;  

elif [ ! -d "$backdir/rec4" ];然后  

        echo "#####在 $BEGINTIME 开始 4 次增量备份到目录 rec4" >>$time_cost  

        $backupbin/ innobackupex --defaults-file=$file_cnf --no-timestamp --user=$user_name --password=$password --slave-info --databases="$db" --incremental --incremental-basedir=$backdir /rec3 $backdir/rec4 1> $out_log 2>&1  

         break;  

elif [ ! -d "$backdir/rec5" ];然后  

        echo "#####在 $BEGINTIME 开始 5 次增量备份到目录 rec5" >>$time_cost  

        $backupbin/ innobackupex --defaults-file=$file_cnf --no-timestamp --user=$user_name --password=$password --slave-info --databases="$db" --incremental --incremental-basedir=$backdir /rec4 $backdir/rec5 1> $out_log 2>&1  

         break;  

 fi  

 ENDTIME=`日期 "%Y-%m-%d %H:%M:%S"`  

 begin_data=`日期 -d  "$ BEGINTIME" %s`  

 end_data=`date -d  "$ENDTIME" %s`  

 spendtime=`expr $end_data - $begin_data`  

 echo "需要$spendtime 秒用于打包数据目录" >>$time_cost  

 

  配置脚本脚本;

  # crontab -l

  10 2 * * *  /opt/cron/mysqldbbakup.sh

  

  

  恢复:

  #全备恢复:

  innobackupex -- apply-log --redo-only  --defaults-file=$file_cnf --user=$user_name --password=$password    $backdir/full

 

  #增备修改恢复,增量目录,逐个apply-log,到第五天的增量rec4都输出都显示innobackupex: Completed OK!

  innobackupex --apply-log --redo-only --defaults-file =$file_cnf --user=$user_name --password=$password    $backdir/full --incremental-dir=$backdir/rec5

  

bitsCN.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
威尔R.E.P.O.有交叉游戏吗?
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

VBOX_E_OBJECT_NOT_FOUND(0x80bb0001)VirtualBox错误 VBOX_E_OBJECT_NOT_FOUND(0x80bb0001)VirtualBox错误 Mar 24, 2024 am 09:51 AM

在VirtualBox中尝试打开磁盘映像时,可能会遇到错误提示,指示硬盘无法注册。这种情况通常发生在您尝试打开的VM磁盘映像文件与另一个虚拟磁盘映像文件具有相同的UUID时。在这种情况下,VirtualBox会显示错误代码VBOX_E_OBJECT_NOT_FOUND(0x80bb0001)。如果您遇到这个错误,不必担心,有一些解决方法可以尝试。首先,您可以尝试使用VirtualBox的命令行工具来更改磁盘映像文件的UUID,这样可以避免冲突。您可以运行命令`VBoxManageinternal

使用飞行模式接收电话的效果如何 使用飞行模式接收电话的效果如何 Feb 20, 2024 am 10:07 AM

飞行模式别人打电话会怎么样手机已经成为人们生活中必不可少的工具之一,它不仅仅是通信工具,还是娱乐、学习、工作等多种功能的集合体。随着手机功能的不断升级和改进,人们对于手机的依赖性也越来越高。在飞行模式出现后,人们可以更方便地在飞行中使用手机。但是,有人担心在飞行模式下别人打电话的情况会对手机或者使用者产生什么样的影响呢?本文将从几个方面来进行分析和讨论。首先

如何使用Laravel开发一个在线餐厅预订系统 如何使用Laravel开发一个在线餐厅预订系统 Nov 02, 2023 pm 01:48 PM

如何使用Laravel开发一个在线餐厅预订系统近年来,随着互联网和移动互联网的快速发展,线上预订已成为现代人生活中不可或缺的一部分。餐饮行业也不例外,越来越多的餐厅开始提供在线预订服务,以提高用户体验和扩大市场份额。本文将介绍如何使用Laravel框架来开发一个简单但功能完善的在线餐厅预订系统,并提供具体的代码示例,方便读者学习和实践。环境搭建首先,我们需要

如何关闭抖音评论功能?关闭抖音评论功能后会怎么样? 如何关闭抖音评论功能?关闭抖音评论功能后会怎么样? Mar 23, 2024 pm 06:20 PM

在抖音平台上,用户不仅可以分享自己的生活点滴,还可以与其他用户互动交流。有时候评论功能可能会引发一些不愉快的经历,如网络暴力、恶意评论等。那么,如何关闭抖音评论功能呢?一、如何关闭抖音评论功能?1.登录抖音APP,进入个人主页。2.点击右下角的“我”,进入设置菜单。3.在设置菜单中,找到“隐私设置”。4.点击“隐私设置”,进入隐私设置界面。5.在隐私设置界面,找到“评论设置”。6.点击“评论设置”,进入评论设置界面。7.在评论设置界面,找到“关闭评论”选项。8.点击“关闭评论”选项,确认关闭评论

Java中的文件包含漏洞及其影响 Java中的文件包含漏洞及其影响 Aug 08, 2023 am 10:30 AM

Java是一种常用的编程语言,用于开发各种应用程序。然而,就像其他编程语言一样,Java也存在安全漏洞和风险。其中一个常见的漏洞是文件包含漏洞(FileInclusionVulnerability),本文将探讨文件包含漏洞的原理、影响以及如何防范这种漏洞。文件包含漏洞是指在程序中通过动态引入或包含其他文件的方式,但却没有对引入的文件做充分的验证和防护,从

数据稀缺对模型训练的影响问题 数据稀缺对模型训练的影响问题 Oct 08, 2023 pm 06:17 PM

数据稀缺对模型训练的影响问题,需要具体代码示例在机器学习和人工智能领域,数据是训练模型的核心要素之一。然而,现实中我们经常面临的一个问题是数据稀缺。数据稀缺指的是训练数据的量不足或标注数据的缺乏,这种情况下会对模型训练产生一定的影响。数据稀缺的问题主要体现在以下几个方面:过拟合:当训练数据量不够时,模型很容易出现过拟合的现象。过拟合是指模型过度适应训练数据,

如何使用Java Websocket实现在线音视频通话? 如何使用Java Websocket实现在线音视频通话? Dec 02, 2023 am 09:44 AM

如何使用JavaWebsocket实现在线音视频通话?在当今数字化时代,实时通信变得越来越普遍。无论是在工作中进行远程协作,还是在家庭中与亲朋好友进行远程交流,实时音视频通话已经成为人们不可或缺的一部分。本文将介绍如何使用JavaWebsocket实现在线音视频通话,并提供具体的代码示例。一、了解WebsocketWebsocket是一种HTML5中的新

硬盘坏道会导致什么问题 硬盘坏道会导致什么问题 Feb 18, 2024 am 10:07 AM

硬盘坏道是指硬盘的物理故障,即硬盘上的储存单元无法正常读取或写入数据。坏道对硬盘的影响是非常显着的,它可能导致数据丢失、系统崩溃和硬盘性能下降等问题。本文将会详细介绍硬盘坏道的影响及相关解决方法。首先,硬盘坏道可能导致数据丢失。当硬盘中的某个扇区出现坏道时,该扇区上的数据将无法读取,从而导致文件损坏或无法访问。这种情况尤其严重,如果坏道所在的扇区中存储了重要

See all articles