IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    备份与还原MySQL从服务器

    OurMySQL发表于 2015-04-08 05:54:13
    love 0

    上一节中我们介绍了如何在CentOS 7上配置MySQL的主从复制模式,今天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.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

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

    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 :o bject_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.

    猜您喜欢

    • 2013 年 5 月 20 日 -- MySQL5.6复制之Binary Log Group Commit
    • 2012 年 11 月 29 日 -- MySQL Replication和Oracle logical standby的原理对比
    • 2012 年 2 月 22 日 -- MYSQL-master-slave实践
    • 2011 年 2 月 24 日 -- PHP查询MySQL大量数据的内存占用分析
    • 2011 年 1 月 28 日 -- 处理Mysql的MySql-bin.0000X日志文件
    • 2010 年 11 月 15 日 -- mysql replication 报告
    • 2009 年 2 月 17 日 -- 配置MySQL远程复制
    • 2009 年 2 月 16 日 -- MySQL双向复制简单配置步骤
    • 2008 年 11 月 18 日 -- 删除MYSQL BIN-LOG 日志
    • 2008 年 11 月 8 日 -- MySQL数据库自动恢复的简单操作过程


沪ICP备19023445号-2号
友情链接