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

percona-xtrabackup备份(potential backups)

nanshan 2025-03-30 19:22 11 浏览 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



相关推荐

ssh终端xshell日志查看命令(xshell怎么看日志)

现在我们云服务器运维较多用的是SSH工具,其中常用的包括PUTTY、XSHELL等,其实大同小异界面UI稍微不同,但是都可以进入远程连接。这里有朋友提到如何查看服务器的日志文件,这个其实和是否使用XS...

使用 Fail Ban 日志分析 SSH 攻击行为

通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...

如何高效读取Linux日志文件?这些命令要熟记于心!

在Linux系统中,日志文件通常存储在/var/log目录下。比如,/var/log/syslog(或/var/log/messages,视发行版而定)记录系统整体事件,/var/log/a...

Windows服务器远程登录日志查询方法,linux查看登录日志方法

概述本文介绍Windows、Linux服务器查询系统的远程登录日志方法。根据服务器所使用的操作系统不同,有以下两种查询方法。Linux操作系统的登录日志查询通过远程连接登录Linux服务器,使用roo...

iptables防火墙如何记录日志(防火墙日志查看)

例如:记录所有ssh服务的登录的日志首先,我们需要了解如何将所有的iptables的INPUT链数据包记录到/var/log/messages中。如果你已经有一些iptables规则了,那么将记录日志...

如何安全管理SSH密钥以防止服务器被入侵

SSH密钥安全管理实施指南(2025年更新版)一、密钥生成与存储规范高强度密钥生成bashCopyCodessh-keygen-ted25519-a100#生成ED25519算法密钥(比...

在CentOS上安装nginx服务器(centos搭建代理服务器)

一、环境描述1.虚拟机配置CPU:单核内存:2GB硬盘:120GBIP:10.24.17.1082.操作系统版本:CentOS6.6x86_64安装方式:Minimal3.虚拟化环境VM...

CentOS7安全加固的一份整理规划建议

◆更新系统:及时更新CentOS7操作系统版本和安全补丁,确保系统以最新状态运行。◆关闭不必要的服务:在运行系统时,应关闭不需要的服务和端口,以减少系统暴露的攻击面。◆安装防火墙:使用iptables...

第四十七天-二叉树,centOS安装tomcat,Maven,vsftpd

学习笔记:1.Maven是Apache下的一个纯Java开发的开源项目。基于项目对象模型(缩写:POM)概念,Maven利用一个中央信息片断能管理一个项目的构建、报告和文档等步骤。Maven...

Linux远程桌面连接使用教程 Widows终端远程连接Linux服务器

一、前言为什么不是远程连接Linux服务器?因为我不会,远程连接window我就用电脑自带的“远程桌面连接”。以下所述都是在CentOS操作系统下的。服务器刚换成Linux的时候很迷茫,感觉无从下手...

CentOS 安全加固操作,保护你的操作系统

系统加固是保障系统安全的重要手段,对于维护企业数据安全、用户隐私以及系统稳定运行具有重要意义。加固后的系统更加健壮和稳定,能够有效减少因安全问题导致的系统故障和停机时间,提高系统的可用性和可靠性。通过...

Dockerfile部署Java项目(docker如何部署java项目)

1、概述本文主要会简单介绍什么是Docker,什么是Dockerfile,如何安装Docker,Dockerfile如何编写,如何通过Dockerfile安装jar包并外置yaml文件以及如何通过do...

CentOS7云主机部署Fail2ban阻断SSH暴力破解

关于Fail2banFail2ban可以监视你的系统日志,然后匹配日志的错误信息(正则式匹配)执行相应的屏蔽动作(一般情况下是调用防火墙屏蔽)例如:当有人在试探你的HTTP、SSH、SMTP、FTP密...

在CentOS7上用源码编译安装PostgreSQL

1、新建postgres用户#useraddpostgres&&passwdpostgres2、安装依赖包#yum-yinstallmakegccgcc-c++readline...

pure-ftpd 使用(ftp prompt命令)

pure-ftpd是一个免费的ftp软件,其他介绍就不多说了。我们直接开始主题安装centosyuminstallepel-releaseyuminstallpure-ftpd配置备份原配置...

取消回复欢迎 发表评论: