使用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主服务器上二进制日志的执行状态。这个数据在还原从服务器的时候至关重要。
使用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设置
解决方法
可以禁用SeLinux(配置文件/etc/selinux/config),
修改完后需要重启。
也可以在tar命令压缩、解压缩时添加如下参数: