当前位置:首页 > Mysql教程 > 列表

快速备份与还原MySQL从服务器步骤

发布:smiling 来源: PHP粉丝网  添加日期:2015-04-16 15:48:51 浏览: 评论:0 

今天Lesca将介绍如何备份和还原MySQL的从服务器,平台仍然是CentOS 7,使用mysqldump进行备份和还原,使用MYSQLDUMP进行备份.

  1. mysqladmin stop-slave -uroot -p 
  2. mysqldump --all-databases > fulldb.dump 
  3. mysqladmin start-slave -uroot -p 
  4. tar -czf /tmp/dbdump.tar.gz ./fulldb.dump ./mysql-relay-log.info 

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

  1. /var/lib/mysql/mysql-relay-bin.000002 
  2. 720 
  3. mysql-bin.0000023968 

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

使用MYSQLDUMP进行还原

  1. mysql -uroot -p < /root/dbdump.db 
  2. stop slave; 
  3. 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; 
  4. start slave; --phpfensi.com 
  5. show slave status\G 

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

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

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

备份数据库文件

  1. service mariadb stop 
  2. tar --selinux --acls --xattrs -czPf /root/dbbackup.tar.gz /var/lib/mysql/ 
  3. service mariadb start 

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

还原数据库文件

  1. service mariadb stop 
  2. tar --selinux --acls --xattrs -xzPf /root/dbbackup.tar.gz -C / 
  3. service mariadb start 

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

故障排查,错误消息:

  1. 150401  9:58:06 [ERROR] mysqld: File '/var/lib/mysql/mysql-bin.index' not found (Errcode: 13) 
  2. 150401  9: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

拓展知识:

  1. -selinux – Save the SELinux context to the archive 
  2. -acls – Save the ACLs to the archive 
  3. -xattrs – Save the user/root xattrs to the archive. It archives all extended attributes, including SELinux and ACLs.

Tags: MySQL备份 MySQL还原

分享到: