当前位置: 移动技术网 > IT编程>数据库>Mysql > xtrabackup备份mysql数据库方法

xtrabackup备份mysql数据库方法

2019年02月21日  | 移动技术网IT编程  | 我要评论

1.安装 xtrabackup 工具包

下载percona yum源

rpm -ivh percona-release-0.1-4.noarch.rpm

通过 yum 方式安装 percona-xtrabackup

yum install percona-xtrabackup -y

*若提示gpg密钥不适用,可以编辑/etc/yum.repos.d/percona-release.repo文件,关闭gpg校验

 

2.通过 innobackupex 备份数据库

连接到服务:innobackupex 或者xtrabackup 通过--user和--password 连接到数据库服务, --defaults-file 指定 mysql 配置文件目录,/mnt 是将备份存放的目录

*可以把数据库用户名和密码添加到my.cnf数据库配置文件中

innobackupex --defaults-file=/etc/my.cnf --user=root /mnt

 ——————————————————————————————

压缩备份(可用参数:--parallel=4:加速备份,这个选项会指定 xtrabackup 备份文件的线程数)

innobackupex --defaults-file=/etc/my.cnf --user=root --stream=tar /mnt | gzip - > /mnt/mysqlbak1.tar.gz

提取压缩

tar -zxivf /mnt/mysqlbak1.tar.gz

 ——————————————————————————————

自动备份脚本

#!/bin/bash
log=mysql_`date +%y%m%d%h%m`.log
str=mysql_`date +%y%m%d%h%m`.tar.gz
innobackupex --defaults-file=/etc/my.cnf --user=root --password=123456 --database=mysql --stream=tar /mnt/autoback_data/ 2>/mnt/autoback_data/$log | gzip
- > /mnt/autoback_data/$str

 

3.恢复数据库

prepare 数据库

创建完备份之后的数据还不能马上用来还原,需要回滚未提交事务,前滚提交事务, 让数据库文件保持一致性

innobackupex --defaults-file=/etc/my.cnf --apply-log /mnt/2019-02-20_10-09-54/
innobackupex --defaults-file=/etc/my.cnf --copy-back /mnt/2019-02-20_10-09-54/

修改恢复的数据目录权限

chown -r mysql:mysql /var/lib/mysql

*数据文件目录可以在my.cnf配置文件中自定义

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网