mysql xtrabackup还原

全量Xtrabackup 恢复:

scp -r /dbbackup/full10.51.1.13320251228 root@10.51.1.132:/

xtrabackup --decompress --parallel=4 --remove-original --target-dir=/full10.51.1.13320251228

xtrabackup --prepare --use-memory=1GB --target-dir=/full10.51.1.13320251228

xtrabackup --defaults-file=/etc/my.cnf --move-back --parallel=4 --target-dir=/full10.51.1.13320251228

  1. 要清空文件binlog、数据文件
  2. 数据文件权限调整成mysql:chown -R mysql:mysql /data/data

全量-增量还原:

(1)恢复完全备份

恢复基础备份加--redo-only,该参数的意思是,只应用xtabackup日志中已经提交的数据,不回滚还未提交的数据

innobackupex --apply-log --redo-only /data2/full10.51.1.13320251228

(2)(将增量备份应用到全备上,注意,这是最后一次增量备份恢复,所以要把redo-only参数去掉,回滚xtrabackup中未提交的数据)

innobackupex --apply-log /data2/full10.51.1.13320251228 --incremental-dir=/data2/incr10.51.1.13320251229

(3)把所有合在一起的完全备份整体进行一次apply操作,回滚未提交的数据

innobackupex --apply-log /data2/full10.51.1.13320251228

备注:记录GTID,做主从使用;要清空文件binlog、数据文件

(4)把恢复完的备份复制到数据文件目录中,给权限,重启数据库

xtrabackup --defaults-file=/etc/my.cnf --move-back --parallel=4 --target-dir=/data2/full10.51.1.13320251228

数据文件权限调整成mysql:chown -R mysql:mysql /data/data

service mysql start

从库配置:

reset master;

reset slave all;

--GTID配置,从备份文件夹里查看xtrabackup_info文件内容的binlog_pos 行的GTID后后面的一串值

SET @@GLOBAL.GTID_PURGED='2f97bf10-0acd-11ea-912f-6c92bf64e6fa:1-8396510;

change master to master_host='主IP',master_user='root',master_password='密码',master_port=3306,MASTER_AUTO_POSITION = 1;

START SLAVE;

相关推荐
jiayou6412 小时前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北13 小时前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤1 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12022 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再3 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip