百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

percona-xtrabackup备份(potential backups)

nanshan 2025-03-30 19:22 18 浏览 0 评论

关键字:Mysql5.7、备份、percona-xtrabackup

版本说明:2.3.3之后不备份死锁,如果数据库是mysql 5.7之后的必须要装2.4.4才可以用,会向下兼容的。

xtrabackup 是用来备份 InnoDB 表的,不能备份非 InnoDB 表,和 mysqld server 没有交互;innobackupex 脚本用来备份非 InnoDB 表,同时会调用 xtrabackup 命令来备份 InnoDB 表,还会和 mysqld server 发送命令进行交互,如加读锁(FTWRL)、获取位点(SHOW SLAVE STATUS)等。简单来说,innobackupex 在 xtrabackup 之上做了一层封装。

一般情况下,我们是希望能备份 MyISAM 表的,虽然我们可能自己不用 MyISAM 表,但是 mysql 库下的系统表 是 MyISAM 的,因此备份基本都通过 innobackupex 命令进行;另外一个原因是我们可能需要保存位点信息。

另外几个工具相对小众些,xbcrypt 是加解密备份文件用的;xbstream 类似于tar,是 Percona 自己实现的一种支持并发写的流文件格式;两者在备份和解压时都会用到(如果备份用了加密和并发)。xbcloud 工具的作用是:把全部或部分 xbstream 档案从云上下载或上传到云。

注意:xtrabackup8.0只支持mysql8.0以上的版本,mysql5.7或以下需要使用xtrabackup8.0以下的版本,文档使用mysql5.7做演示

一、安装Percona XtraBackup

//安装yum 源

[root@mayi ~]# yum install https://repo.percona.com/yum/percona-release-latest.noarch.rpm
[root@mayi ~]# yum list|grep percona-xtrabackup
[root@mayi ~]# yum -y install percona-xtrabackup-24.x86_64
[root@mayi ~]# mkdir /data/backup/full/
[root@mayi ~]# mkdir /data/backup/rec/

二、备份不打包:

2.1、全实例

备份:
[root@mayi ~]# innobackupex  --socket=/dev/shm/mysql.sock --user=root --password='123456' /data/backup/full/ 

还原:
[root@mayi ~]# service mysql stop
[root@mayi ~]# mv /data/mysql /data/mysql.bak
[root@mayi ~]# mkdir /data/mysql
[root@mayi ~]# innobackupex  --apply-log   /data/backup/full/2021-05-10_17-22-44/
[root@mayi ~]# innobackupex  --socket=/dev/shm/mysql.sock --user=root --copy-back /data/backup/full/2021-05-10_17-22-44/
[root@mayi ~]# chown -R mysql:mysql /data/mysql
[root@mayi ~]# service mysql start

当然这里可以在数据库里面新增一个复制权限的用户用于备份

create user 'backup'@'localhost' identified by 'backup';
grant reload, lock tables, process, replication client on *.* to 'backup'@'localhost';
flush privileges;

备份tar打包[常用]:

3.1、全实例备份还原

压缩成一个tar文件,进行备份

备份:
[root@mayi ~]# innobackupex --socket=/dev/shm/mysql.sock --user=root  --password=123456   --stream=tar /data/backup/full |gzip > /data/backup/full/full.tar.gz
还原:
[root@mayi ~]# tar -zxvf /data/backup/full/full.tar.gz  -C /data/backup/full/tmp
[root@mayi ~]# systemctl stop mysqld 
[root@mayi ~]# mv /data/mysql /data/mysql.bak
[root@mayi ~]# mkdir /data/mysql
[root@mayi ~]# innobackupex  --apply-log   /data/backup/full/tmp/
[root@mayi ~]# innobackupex --socket=/dev/shm/mysql.sock --user=root --copy-back  /data/backup/full/tmp/
[root@mayi ~]# chown -R mysql:mysql /data/mysql
[root@mayi ~]# service mysql start

3.2、单库备份还原

备份:
[root@mayi ~]# innobackupex --socket=/dev/shm/mysql.sock --user=root --password='123456' --databases=mayi --stream=tar /data/backup/full/ |gzip > /data/backup/full/mayi.tar.gz
还原:
[root@mayi ~]# mkdir -p /data/backup/full/mayi
[root@mayi ~]# cd /data/backup/full/
[root@mayi full]# tar -zxcf mayi.tar.gz -C mayi
[root@mayi full]# innobackupex --socket=/dev/shm/mysql.sock --user=root --password='123456' --apply-log --export /data/backup/full/mayi/
[root@mayi full]# systemctl stop mysqld
[root@mayi full]# \cp -rf mayi/* /data/mysql/ 
[root@mayi full]# systemctl start mysqld

三、增量备份

备份:
[root@mayi ~] innobackupex --socket=/dev/shm/mysql.sock --user=root --password=123456 --incremental --incremental-basedir=/data/backup/full/2021-05-10_16-20-45 /data/backup/rec

恢复增量数据
1、关闭数据库
[root@mayi ~] systemctl stop mysqld
2、删除数据文件
[root@mayi ~] rm -rf /data/mysql/*
3、恢复基础数据
[root@mayi ~] innobackupex --apply-log /data/backup/full/2021-05-10_16-20-45/
4、增量数据1追加到基础数据
[root@mayi ~] innobackupex --apply-log /data/backup/full/2021-05-10_16-20-45/ --incremental-dir=/data/backup/rec/2021-05-10_16-44-45/
5、拷贝数据
[root@mayi ~] innobackupex --defaults-file=/etc/my.cnf --copy-back /data/backup/full/2021-05-10_16-20-45/
6、文件权限
[root@mayi ~] chown -R mysql.mysql /data/mysql
7、启动服务
[root@mayi ~] systemctl start mysqld



相关推荐

安全软件更新:OpenSSH 9.3和OpenSSL 3.1

最近开源安全软件领域也相继更新了最新版本。其中上周OpenSSL发布了最新的3.1版本,而OpenSSH则在昨天发布最新版本9.3。虽然带来的新功能不多,只是bug和漏洞方面的修复,但是作为比较重要的...

阿里云新增的轻量应用服务器(欧洲与美洲)美国(硅谷)配置方法

近期,阿里云的轻量应用服务器新增了欧洲与美洲地域,可以在美国(硅谷)部署服务器了,但是没有LAMP应用镜像,所以在配置服务器时遇到几个问题,SSH登录不了,提示【Algorithmnegotiati...

OpenSSH 10.0发布 旨在更好地抵御量子计算机的攻击

OpenSSH10.0现已支持这一广泛使用的SSH客户端/服务器实现。OpenSSH10.0包含多项改进,包括更好地防御未来量子计算机可能发起的攻击。OpenSSH10.0放弃了对过去...

腾讯云国际站: 腾讯云服务器怎麽SSH远程连接

本文由【云老大】TG@yunlaoda360撰写准备工作获取服务器的公网IP地址:在腾讯云控制台找到云服务器实例,查看其基本信息,获取公网IP地址。确保服务器已安装SSH服务:一般Linux系统默...

旧电脑改服务器,这 6 个坑能让你白忙 3 天(附实测解决办法)

前几天收到粉丝私信,说照着教程把旧电脑改成服务器,结果折腾了3天还是没成功——要么是启动后连不上网,要么是跑两天就自动关机。其实我第一次改的时候也踩了不少坑,光是让旧电脑稳定运行,就重装了6...

使用win10自带的ssh服务器

我太喜欢ssh了,因为它的功能实在太强大,而且几乎不占用啥资源。(PS:类似的软件:p7zip,tightvnc)。因此,无论是哪个系统,我总想着安装一个ssh的服务器。之前我在虚拟机中安装了个win...

Python sys模块使用教程

1.知识导图2.sys模块概述2.1模块定义与作用sys模块是Python标准库中的一个内置模块,提供了与Python解释器及其环境交互的接口。它包含了许多与系统相关的变量和函数,可以用来控制P...

满足AI时代高效办公需求 惠普战99 AI商务超能本评测

身处智能化时代的浪潮之中,人工智能正在深刻影响着我们工作和生活的方式,从聊天机器人到自动驾驶,从智能制造到药物研发,人工智能的力量无处不在。如今,随着各类AI应用逐渐占据主流计算平台,并在各种触手可及...

使用 vLLM 生产环境部署 DeepSeek,算力减半、吞吐增十倍!

需求:之前使用Ollama部署过deepseek-r1:32b模型,非常方便快捷,适合个人快速部署使用。如果作为企业生产环境应该使用什么方式部署呢?一般都采用vllm、sglang进行部署...

我把 ML 模型编译成 C 后,速度竟提升了 1000 倍!

【CSDN编者按】在本文中,我们来尝试将micrograd神经网络编译成C。具体内容如下:简单了解一下神经网络;看看micrograd如何前向传播和反向传播;复习链式法则;分析为什么mi...

这才是真·非公旗舰!索泰RTX 5080天启OC显卡评测

近年来,电脑硬件的RGB灯光逐渐成为标配,厂商在产品差异化这一方面则开拓了二次元IP形象这一新的领域,但要说哪家厂商在这一领域最吸引眼球,我想索泰应该要属独领风骚的一个。早在2020年,索泰便推出了以...

性能测试工具Iperf 验证SDN网络

1实验目的掌握Iperf在Linux环境下的安装和常用命令行参数的含义熟悉Iperf应用实例掌握SDN网络中使用Iperf测试网络带宽等2实验原理网络性能测试主要是监测网络带宽的使用率,将网络带宽...

方案 | 感受沉浸式音效的魅力:Roger和他的豪华影院

随着沉浸式音效的不断普及,诸如杜比全景声、DTS:X或Auro3D等技术不断引入到家庭影院音响系统中来,并带来了前所未有的震撼效果。也因此,越来越多的业主想要搭建一间具备沉浸式音效的影院,以享受更高...

LLVM IR入门:编写自定义优化Pass的完整教程与性能影响分析

LLVMIR:编译器优化的核心纽带LLVM作为模块化编译器框架的典范,其中间表示(IR)是连接前端(如Clang)与后端(目标架构代码生成)的桥梁。与传统编译器不同,LLVMIR具有平台无关性和...

iperf-LINUX测速工具

#iperf-测速工具安装包下载地址https://github.com/esnet/iperfhttps://downloads.es.net/pub/iperf/iperf-3.9.tar.gz官...

取消回复欢迎 发表评论: