时间:2021-07-01 10:21:17 帮助过:11人阅读
通过客户端命令工具:mysqlbinlog和二进制日志恢复数据库文件
mysqlbinlog [options] log_file ...
--start-datetime=
--stop-datetime=
--start-position=
--stop-position=
第一步:算好要恢复数据的时间段,重定向输入到bin.sql文件中
#通过时间轴
mysqlbinlog --start-datetime="2019-06-08 22:55:13" --stop-datetime="2019-06-08 22:55:13" binlog.0000011 > bin.sql
#通过position日志位置
mysqlbinlog /var/lib/mysql/mysqlbin.000001 --stop-pos=1093 | mysql -uroot -proot
第二步:执行bin.sql文件还原
source bin.sql
第一步:请求锁定所有表
flush tables with read lock;
第二步:记录二进制日志文件及事件位置或时间点
flush logs;
mysql -uroot -proot -e 'show master status;' > /path/to/somefile
第三步:创建快照
lvcreate -L # -s -p r -n NAME /DEV/VG_NAME/LV_NAME
第四步:释放锁
unlock tables;
第五步:挂在快照卷,执行数据备份
第六步:备份完成后,删除快照卷
第七步:指定好策略,通过原卷备份二进制日志
第八步:还原的时候确保属组和属主是mysql:mysql
其中:如果是yum安装默认数据目录在/var/lib/mysql,如果需要更改
╭─root@localhost.localdomain /var/lib/mysql
╰─? vim /etc/my.cnf.d/server.cnf
[mysqld]
datadir=/mysql_data/
pid_file=/mysql_data/localhost.pid
socket=/mysql_data/mysql.sock
wsrep_data_home_dir=/mysql_data/
log-bin=mysql-bin
[client]
socket=/mysql_data/mysql.sock
注意:在MariaDB10.3.x及以上的版本用Percona XtraBackup工具会有问题;原因可能是MariaDB10.3以上版本的redo日志格式和之前不同了
官方文档
Percona的官方文档:https://www.percona.com/doc/percona-xtrabackup/2.4/index.html
Mariabackup的官方文档:https://mariadb.com/kb/en/library/mariabackup-overview/
安装方法
yum install MariaDB-backup
备份与恢复
全备+恢复
#全量备份
mariabackup --backup --target-dir=/root/fullbackup --user=root --password=root
#准备全备数据
mariabackup --prepare --target-dir=/root/fullbackup/ --user=root --password=root
#还原数据(请确保数据目录下是空的)
mariabackup --copy-back --target-dir=/root/fullbackup/ --user=root --password=root
#修改属组和属主
chown -R mysql.mysql /var/lib/mysql
全备+增量+恢复
#1.全量备份
mariabackup --backup --target-dir=/root/fullbackup --user=root --password=root
#2.增量备份
mariabackup --backup --target-dir=/root/inc1 --incremental-basedir=/root/fullbackup/ --user=root --password=root
#3.准备全备数据
mariabackup --prepare --target-dir=/root/fullbackup/ --user=root --password=root
#4.增量和全备数据合并
mariabackup --prepare --target-dir=/root/fullbackup/ --user=root --password=root --incremental-dir=/root/inc1/ --apply-log-only
#5.恢复数据(请确保数据目录下是空的)
mariabackup --copy-back --target-dir=/root/fullbackup/ --user=root --password=root
#6.修改属组和属主
chown -R mysql.mysql /var/lib/mysql
数据库备份和恢复---MariaDB
标签:对象 host flush back 基于 rem stop 文件的 home