今天Lesca将介绍如何备份和还原MySQL的从服务器,平台仍然是CentOS 7,使用mysqldump进行备份和还原,使用MYSQLDUMP进行备份.
- mysqladminstop-slave-uroot-p
- mysqldump--all-databases>fulldb.dump
- mysqladminstart-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.0000023968
红色高亮部分,指明了当前MySQL主服务器上二进制日志的执行状态,这个数据在还原从服务器的时候至关重要.
使用MYSQLDUMP进行还原
- mysql-uroot-p</root/dbdump.db
- stopslave;
- CHANGEMASTERTOMASTER_HOST='192.168.10.201',MASTER_USER='slave_user',MASTER_PASSWORD='abc@DEF',MASTER_LOG_FILE='mysql-bin.000002',MASTER_LOG_POS=3968;
- startslave;--phpfensi.com
- showslavestatus\G
在状态中,如果有下面两行,则表示从服务器工作正常:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
使用数据库文件(Raw Data)进行备份和还原
备份数据库文件
- servicemariadbstop
- tar--selinux--acls--xattrs-czPf/root/dbbackup.tar.gz/var/lib/mysql/
- servicemariadbstart
注意:红色参数让tar同时备份selinux属性和其他ACL属性,以防止还原到目标服务器后无法使用.
还原数据库文件
- servicemariadbstop
- tar--selinux--acls--xattrs-xzPf/root/dbbackup.tar.gz-C/
- servicemariadbstart
同时,还原数据文件的时候,也需要指定这些参数.
故障排查,错误消息:
- 1504019:58:06[ERROR]mysqld:File'/var/lib/mysql/mysql-bin.index'notfound(Errcode:13)
- 1504019:58:06[ERROR]Aborting
检查SELINUX设置:
ll -Z mysql-bin.index
-rw-rw----. mysql mysql unconfined_u :o bject_r:var_lib_t:s0 mysql-bin.index
解决方法:
可以禁用SeLinux(配置文件/etc/selinux/config),SELINUX=disabled 修改完后需要重启.
也可以在tar命令压缩、解压缩时添加如下参数:
tar --selinux --acls --xattrs
拓展知识:
- -selinux–SavetheSELinuxcontexttothearchive
- -acls–SavetheACLstothearchive
- -xattrs–Savetheuser/rootxattrstothearchive.Itarchivesallextendedattributes,includingSELinuxandACLs.