今天Lesca将介绍如何备份和还原MySQL的从服务器,平台仍然是CentOS 7。
使用mysqldump进行备份和还原
使用mysqldump进行备份
mysqladmin stop-slave -uroot -p
mysqldump --all-databases > 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),该文件包含类似如下信息:
/var/lib/mysql/mysql-relay-bin.000002
720
mysql-bin.000002
3968
红色高亮部分,指明了当前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 statusG
在状态中,如果有下面两行,则表示从服务器工作正常:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
使用数据库文件(Raw Data)进行备份和还原
备份数据库文件
service mariadb stop
tar --selinux --acls --xattrs -czPf /root/dbbackup.tar.gz /var/lib/mysql/
service mariadb start
注意:红色参数让tar同时备份selinux属性和其他ACL属性,以防止还原到目标服务器后无法使用。
还原数据库文件
service mariadb stop
tar --selinux --acls --xattrs -xzPf /root/dbbackup.tar.gz -C /
service mariadb start
同时,还原数据文件的时候,也需要指定这些参数。
故障排查
错误消息
150401 9:58:06 [ERROR] mysqld: File '/var/lib/mysql/mysql-bin.index' not found (Errcode: 13)
150401 9:58:06 [ERROR] Aborting
检查SeLinux设置
ll -Z mysql-bin.index
-rw-rw----. mysql mysql unconfined_u:object_r:var_lib_t:s0 mysql-bin.index
解决方法
可以禁用SeLinux(配置文件/etc/selinux/config),
SELINUX=disabled
修改完后需要重启。
也可以在tar命令压缩、解压缩时添加如下参数:
tar --selinux --acls --xattrs
拓展知识
–selinux – Save the SELinux context to the archive
–acls – Save the ACLs to the archive
–xattrs – Save the user/root xattrs to the archive. It archives all extended attributes, including SELinux and ACLs.
米加小镇世界龙年无广告版 安卓版v1.81
米加小镇世界龙年无广告是一款模拟类手游,不少的玩家可能都玩过
部落冲突互通服 安卓版v17.100.1
部落冲突互通服是全球风靡的战争策略手游,连接安卓和iOS服务
我的世界恶魔模组资源包 (EDU HELL)最新版vDEATH
我的世界恶魔版是一款像素风格的开放世界沙盒游戏,游戏中你可以
艺术大亨天天拍卖变富翁 最新安卓版v1.31.0
艺术大亨天天拍卖变富翁是一款非常好玩的模拟经营类手游,在游戏
大型巴士司机游戏 安卓版v2.1.0
大型巴士司机是一款模拟驾驶类游戏,玩家们将在游戏中化身为大巴