当前位置: 首页 > 编程笔记 >

使用xtrabackup实现mysql备份

戚明朗
2023-03-14
本文向大家介绍使用xtrabackup实现mysql备份,包括了使用xtrabackup实现mysql备份的使用技巧和注意事项,需要的朋友参考一下

下载地址:https://www.percona.com/downloads/XtraBackup/

安装xtrabackup

[root@node1 ~]# yum install percona-xtrabackup

完全备份

节点一

修改配置文件,设置为每张表单独一个表空间,此项必须在安装数据库的时候就设置

[root@node1 ~]# vim /etc/my.cnf
[mysqld]
innodb_file_per_table=ON

创建备份目录

[root@node1 ~]# mkdir /backpus/

备份

[root@node1 ~]# innobackupex --user=root /backpus/

复制给节点2

[root@node1 ~]# scp -r /backpus/2016-07-13_20-27-04 192.168.1.114:/root/

节点二

(节点二的mysql安装后不要启动,启动后因生成有初始化文件无法还原)

[root@node2 ~]# yum install percona-xtrabackup

把备份文件移动到/backups目录下

[root@node2 ~]# mkdir /backups/
[root@node2 ~]# mv 2016-07-13_20-27-04/ /backups/

对备份文件进行整理

[root@node2 ~]# innobackupex --apply-log /backups/2016-07-13_20-27-04/

还原

[root@node2 ~]# innobackupex --copy-back /backups/2016-07-13_20-27-04/

修改文件权限

[root@node2 ~]# chown -R mysql:mysql /var/lib/mysql/*

增量备份

修改数据

[root@node1 ~]# mysql
MariaDB [(none)]> use hellodb;
MariaDB [hellodb]> create table xxoo2 (id int);
MariaDB [hellodb]> insert into xxoo2 values (1),(10),(83);

对之前完全备份的文件进行增量备份

[root@node1 ~]# innobackupex --incremental /backpus/ --incremental-basedir=/backpus/2016-07-13_20-27-04

对完全备份做只读,为增量和完全合并做准备

[root@node1 ~]# innobackupex --apply-log --redo-only /backpus/2016-07-13_20-27-04/

合并增量到完全中

[root@node1 ~]# innobackupex --apply-log --redo-only /backpus/2016-07-13_20-27-04/ --incremental-dir=/backpus/2016-07-13_23-13-25/

查看增量备份文件

[root@node1 ~]# less /backpus/2016-07-13_23-13-25/xtrabackup_checkpoints 
backup_type = incremental
from_lsn = 1642047
to_lsn = 1646912
last_lsn = 1646912
compact = 0

查看完全备份文件

[root@node1 ~]# less /backpus/2016-07-13_20-27-04/xtrabackup_checkpoints
backup_type = full-prepared
from_lsn = 0
to_lsn = 1646912
last_lsn = 1646912
compact = 0

之后如果有新的增量备份文件还可以继续在完全备份文件上合并 还原时将完全备份文件拿去还原即可

注意:mysql的访问权限,我操作过程中多次出现错误,都是在mysql数据库的属主和属组权限出现的问题。

 类似资料:
  • 本文向大家介绍xtrabackup备份还原MySQL数据库,包括了xtrabackup备份还原MySQL数据库的使用技巧和注意事项,需要的朋友参考一下 mysqldump 备份鉴于其自身的某些特性(锁表,本质上备份出来insert脚本或者文本,不支持差异备份),不太适合对实时性要求比较高的情况 Xtrabackup可以解决mysqldump存在的上述的一些问题,生产环境应用的也会更多一些。 本文简

  • 本文向大家介绍使用mysqldump实现mysql备份,包括了使用mysqldump实现mysql备份的使用技巧和注意事项,需要的朋友参考一下 注意:备份文件和二进制日志文件不能与mysql放在同一磁盘下 节点1 1、节点1上修改mysql配置文件,开起二进制日志保存 这里我将二进制日志放在/data/mysql/目录下,/data/是我创建的另外一个lvm磁盘,本来想直接放在/data/下,发现

  • 本文向大家介绍安装使用Percona XtraBackup来备份恢复MySQL的教程,包括了安装使用Percona XtraBackup来备份恢复MySQL的教程的使用技巧和注意事项,需要的朋友参考一下 1.安装XtraBackup yum的安装方法: 自动 然后会看到: 手动 测试安装库 使用yum list | grep percona来确保安装 会出现以下信息:   2、进行完整备份 备份必

  • 本文向大家介绍MySQL使用LVM快照实现备份,包括了MySQL使用LVM快照实现备份的使用技巧和注意事项,需要的朋友参考一下 新建一个lvm磁盘,这里我建的lv为mydatalv,挂载到了/data下 将原数据库文件复制到/data目录下 [root@localhost ~]# cp -a /var/lib/mysql /data/ 修改配置文件,将mysql数据库文件放在lvm盘中,二进制文件

  • 本文向大家介绍MySQL中使用innobackupex、xtrabackup进行大数据的备份和还原教程,包括了MySQL中使用innobackupex、xtrabackup进行大数据的备份和还原教程的使用技巧和注意事项,需要的朋友参考一下 大数据量备份与还原,始终是个难点。当MYSQL超10G,用mysqldump来导出就比较慢了。在这里推荐xtrabackup,这个工具比mysqldump要快很

  • 本文向大家介绍编写脚本令Xtrabackup对MySQL数据进行备份的教程,包括了编写脚本令Xtrabackup对MySQL数据进行备份的教程的使用技巧和注意事项,需要的朋友参考一下 Xtrabackup备份恢复原理 备份innodb表时,xtrabackup若干个线程拷贝独立表空间的.ibd文件,并不停监视此过程中redo log的变化,添加到自己的事务日志文件(xtrabackup_logfi