介绍备份和还原MySQL数据的两种方法

使用MysqLdump进行备份和还原
使用MysqLdump进行备份

fulldb.dump MysqLadmin start-slave -uroot -p tar -czf /tmp/dbdump.tar.gz ./fulldb.dump ./MysqL-relay-log.info

我们除了要备份了整个数据库的dump以外,还需要备份relay-log.info文件(上例为MysqL-relay-log.info),该文件包含类似如下信息:

MysqL/MysqL-relay-bin.000002 720 MysqL-bin.0000023968

红色高亮部分,指明了当前MysqL主服务器上二进制日志的执行状态。这个数据在还原从服务器的时候至关重要。

使用MysqLdump进行还原

MysqL -uroot -p < /root/dbdump.db stop slave; CHANGE MASTER TO MASTER_HOST='192.168.10.201',MASTER_USER='slave_user',MASTER_PASSWORD='abc@DEF',MASTER_LOG_FILE='MysqL-bin.000002',MASTER_LOG_POS=3968; start slave; show slave status\G

在状态中,如果有下面两行,则表示从服务器工作正常:

sql_Running: Yes

使用数据库文件(Raw Data)进行备份和还原
备份数据库文件

MysqL/ service mariadb start

注意:红色参数让tar同时备份selinux属性和其他ACL属性,以防止还原到目标服务器后无法使用。
还原数据库文件

同时,还原数据文件的时候,也需要指定这些参数。

故障排查

错误消息

MysqLd: File '/var/lib/MysqL/MysqL-bin.index' not found (Errcode: 13) 150401 9:58:06 [ERROR] Aborting

检查SeLinux设置

MysqL-bin.index -rw-rw----. MysqL MysqL unconfined_u :o bject_r:var_lib_t:s0 MysqL-bin.index

解决方法

可以禁用SeLinux(配置文件/etc/selinux/config),

修改完后需要重启。

也可以在tar命令压缩、解压缩时添加如下参数:

相关文章

(一)日志传送架构 (1.1)相关服务器 主服务器 :用于生产的服务器,上面运行这生产SQL Server数据库...
(一)事故背景 最近在SQL Server 2012生产数据库上配置完事物复制(发布订阅)后,生产数据库业务出现了...
(一)测试目的 目前公司使用的SQL SERVER 2012高可用环境为主备模式,其中主库可执行读写操作,备库既...
(一)背景个人在使用sql server时,用到了sql server的发布订阅来做主从同步,类似MySQL的异步复制。在...
UNION和OR谓词 找出 product 和 product2 中售价高于 500 的商品的基本信息. select * from product wh...
datawhale组队学习task03