服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|

服务器之家 - 数据库 - Mysql - mysql xtrabackup 备份恢复实现分享

mysql xtrabackup 备份恢复实现分享

2019-12-13 11:48MYSQL教程网 Mysql

Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具

简介 
Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具。特点: 
(1)备份过程快速、可靠; 
(2)备份过程不会打断正在执行的事务; 
(3)能够基于压缩等功能节约磁盘空间和流量; 
(4)自动实现备份检验; 
(5)还原速度快; 
Xtrabackup中包含两个工具: 
* xtrabackup - 用于热备份innodb, xtradb表的工具,不能备份其他表。 
* innobackupex - 对xtrabackup封装的perl脚本,提供了MyISAM表备份的能力。(能进行整库和数据表备份)。 
使用innobakupex备份时,其会调用xtrabackup备份所有的InnoDB表,复制所有关于表结构定义的相关文件(.frm)、以及MyISAM、MERGE、CSV和ARCHIVE表的相关文件, 
同时还会备份触发器和数据库配置信息相关的文件。这些文件会被保存至一个以时间命令的目录中。 
在备份的同时,innobackupex还会在备份目录中创建如下文件: 
(1)xtrabackup_checkpoints —— 备份类型(如完全或增量)、备份状态(如是否已经为prepared状态)和LSN(日志序列号)范围信息;每个InnoDB页(通常为16k大小)都会包含一个日志序列号,即LSN。LSN是整个数据库系统的系统版本号,每个页面相关的LSN能够表明此页面最近是如何发生改变的。 
(2)xtrabackup_binlog_info —— mysql服务器当前正在使用的二进制日志文件及至备份这一刻为止二进制日志事件的位置。 
(3)xtrabackup_binlog_pos_innodb —— 二进制日志文件及用于InnoDB或XtraDB表的二进制日志文件的当前position。 
(4)xtrabackup_binary —— 备份中用到的xtrabackup的可执行文件; 
(5)backup-my.cnf —— 备份命令用到的配置选项信息; 
在使用innobackupex进行备份时,还可以使用--no-timestamp选项来阻止命令自动创建一个以时间命名的目录;innobackupex命令将会创建一个BACKUP-DIR目录来存储备份数据。 
二进制版本 
http://www.percona.com/downloads/XtraBackup/ 
wget http://www.percona.com/downloads/XtraBackup/LATEST/binary/Linux/x86_64/percona-xtrabackup-2.0.3-470.tar.gz 
tar zxvf percona-xtrabackup-2.0.3-470.tar.gz 
cd percona-xtrabackup-2.0.3/bin 
cp * /usr/bin/ 
本次使用的是mysql5.5.28安装在此不叙述 
建一个用于数据备份的目录 
mkdir -p /opt/mysql_bak/ 
修改数据库配置文件: 
vim /etc/my.cnf 
datadir = /home/mysql/data/ 
mysqladmin -uroot password 123456 
整库备份: 
innobackupex --user=root --password=123456 --defaults-file=/etc/my.cnf /opt/mysql_bak/ 
单独备份: 
innobackupex --user=root --password=123456 --defaults-file=/etc/my.cnf --database=test /opt/mysql_bak 
备份并打包压缩: 
innobackupex --user=root --password=123456 --defaults-file=/etc/my.cnf --database=test --stream=tar /opt/mysql_bak/ | gzip > /opt/mysql_bak/testdb.tar.gz 
带时间戳 
innobackupex --user=root --password=123456 --defaults-file=/etc/my.cnf --database=test --stream=tar /opt/mysql_bak/ | gzip > /opt/mysql_bak/`date +%F`_testdb.tar.gz

延伸 · 阅读

精彩推荐
  • MysqlMySQL不支持InnoDB的解决方法

    MySQL不支持InnoDB的解决方法

    在OpenSUSE下装上MySQL后,发现无法选择添加事务支持数据引擎InnoDB。 ...

    mysql教程网2292019-11-04
  • MysqlMysql服务器的启动与停止(二)

    Mysql服务器的启动与停止(二)

    三、 停止 服务器 要手工 启动 服务器,使用MySQLadmin: %mysqladminshutdown 要自动停止服务器,你不需做特别的事情。BSD系统一般通过向进程发一个TERM信号停止...

    Mysql教程网4032019-10-15
  • MysqlMySQL数据库安全配置介绍

    MySQL数据库安全配置介绍

    MySQL数据库所在的主机的安全性是最首要的问题,如果主机不安全,被攻击者控制,那么MySQL的安全性也无从谈起。其次就是数据目录和数据文件的安全性,...

    mysql教程网4862019-11-15
  • Mysqlmysql中插入emoji表情失败的原因与解决

    mysql中插入emoji表情失败的原因与解决

    这篇文章主要给大家介绍了关于mysql中插入emoji表情失败的原因与解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习...

    许渺2042019-06-13
  • MysqlMysql 错误问题汇总(不断更新中)

    Mysql 错误问题汇总(不断更新中)

    Mysql 错误问题汇总,我们在开发过程中经常看到mysql的一些错误,这里整理下,方便需要的朋友 ...

    MYSQL教程网3472019-12-04
  • MysqlMySQL主从同步、读写分离配置步骤

    MySQL主从同步、读写分离配置步骤

    根据要求配置MySQL主从备份、读写分离,结合网上的文档,对搭建的步骤和出现的问题以及解决的过程做了如下笔记 ...

    MYSQL教程网3462019-12-01
  • Mysqlmysql从执行.sql文件时处理\n换行的问题

    mysql从执行.sql文件时处理\n换行的问题

    后来注意到,在上面我们恢复数据的时候是在没有连接数据的状态下执行的。 ...

    mysql教程网2142019-10-27
  • MysqlMySQL中文乱码问题的解决

    MySQL中文乱码问题的解决

    下面要写的是一篇非常无聊的东西,充斥了大量各式各样的编码、转换、客户端、服务器端、连接呃,我自己都不愿意去看它,但想一想,写下来还是有点...

    mysql技术网4492019-10-16