返回顶部
首页 > 资讯 > 数据库 >MySQL恢复:使用从库备份,主库binlog,从库中继日志恢复数据库
  • 797
分享到

MySQL恢复:使用从库备份,主库binlog,从库中继日志恢复数据库

2024-04-02 19:04:59 797人浏览 泡泡鱼
摘要

小生博客:Http://xsboke.blog.51cto.com -------谢谢您的参考,如有疑问,欢迎交流 环境说明: Mysql主从复制,主库A宕机,将从

小生博客:Http://xsboke.blog.51cto.com

                -------谢谢您的参考,如有疑问,欢迎交流

环境说明:

    Mysql主从复制,主库A宕机,将从库B提升为了主库(假设你这时候才开启了从库的binlog日志)
    现在要新搞一个数据库C用来替代旧的主库A,那么C库的数据肯定要以B库为主,
    所以我们使用B库的备份来恢复数据

    将B作为主,C库作为从,
    你需要将C库恢复到B库提升为主库时的数据,才可以将C库作为新的从库使用(才可以change master)

以A库的binlog日志为主,介绍当前的备份状态:

    mysql-bin.00100
    mysql-bin.00101         在mysql-bin.00101的时候从库做了备份并且保有slave status信息
    mysql-bin.00102
    mysql-bin.00103
    mysql-bin.00104         主库是在mysql-bin.00104的时候宕机的
    mysql-bin.00105

所以我打算这样做:

1. 用从库的全备恢复数据,
2. 然后用主库的binlog恢复后来的数据,
3. 再使用从库的中继日志恢复主库缺少的数据.
在这过程中我发现了问题(关于[3.]的解释):
    主库宕机时,我发现有几条数据主库的binlog日志没有,但是从库的中继日志中却有,
    所以我从中继日志中把主库没有但是从库有的sql复制了出来,
    然后放到了文件名为addsql.sql中

我在mysql-bin.00101时的全备,备份时从库的slave status是这样的:

                Master_Log_File: mysql-bin.00101
                Read_Master_Log_Pos: 888301479
                Relay_Log_File: relay-bin.000002
                Relay_Log_Pos: 31921757
                Relay_Master_Log_File: mysql-bin.00100     # 从库SQL线程已经执行到的binlog日志
                Slave_io_Running: No
                Slave_SQL_Running: No
                Replicate_Do_DB:
                Replicate_Ignore_DB:
                Replicate_Do_Table:
                Replicate_Ignore_Table:
                Replicate_Wild_Do_Table:
                Replicate_Wild_Ignore_Table:
                Last_Errno: 0
                Last_Error:
                Skip_Counter: 0
                Exec_Master_Log_Pos: 31921467                   # 从库SQL线程已经执行到的binlog日志的position
                Relay_Log_Space: 1962055058

注意:如果要使C库数据和B库一样,那么要以Relay_Master_Log_File和Exec_Master_Log_Pos这两个参数为准恢复数据

我的操作流程是这样的:

    1. 首先在C库上导入,在mysql-bin.00101的时候从库的备份,
    2. 根据从库做全备时保留的slave status,将mysql-bin.00100中还没有同步的数据导出为sql,(mysqlbinlog --start-position=31921467 /mysql-bin.00100 > ./100.sql).
    3. 然后陆续将mysql-bin.00101之后和主库宕机时mysql-bin.00104的binlog日志转为sql.
    4. 将这些sql导入.
    5. 将addsql.sql导入.
    6. B库授权replication slave,然后C库change master 到B库即可
您可能感兴趣的文档:

--结束END--

本文标题: MySQL恢复:使用从库备份,主库binlog,从库中继日志恢复数据库

本文链接: https://lsjlt.com/news/44527.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL恢复:使用从库备份,主库binlog,从库中继日志恢复数据库
    小生博客:http://xsboke.blog.51cto.com -------谢谢您的参考,如有疑问,欢迎交流 环境说明: mysql主从复制,主库A宕机,将从...
    99+
    2024-04-02
  • 《MySQL数据库》MySQL备份恢复
    前言 MySQL数据库最重要的部分就是数据,所以保证数据不被损坏尤为重要,大家都知道911事件,当时非常多的数据丢失,导致经济混乱。接下来我们就来讲讲MySQL是如何保障数据完整,应对特殊情况,如何恢复等。 备份 备份检查:保证备份没有问题...
    99+
    2016-12-27
    《MySQL数据库》MySQL备份恢复 数据库入门 数据库基础教程 数据库 mysql
  • 使用XtraBackup恢复|备份 Mysql数据库 -- 数据恢复篇
                                 ...
    99+
    2024-04-02
  • 【备份恢复】}异机备份恢复数据库
    此实验是在B库上恢复A库,不过更改了实例名。 目标库只是按照到oracle软件为止。 源库(A库):  192.168.56.12 ORACLE_SID=DBdb DBID=328289773...
    99+
    2024-04-02
  • MySQL数据库备份和恢复
    目录 MySQL数据库备份和恢复 备份恢复概述 为什么要备份 备份注意要点 还原要点 备份类型: 备...
    99+
    2015-03-06
    MySQL数据库备份和恢复
  • Mysql数据库备份与恢复
    1 数据备份与恢复2 使用第三方软件进行备份1 数据备份与恢复1.1 数据备份方式物理备份:直接拷贝库或者表对应的文件。cp,tar, ...具有局限性,前提是表的存储引擎为myisam,跨平台性...
    99+
    2024-04-02
  • xtrabackup备份恢复MySQL数据库
    1. 全量备份恢复: 查看原表内容: MariaDB [(none)]> select * from testdb.students; +----+------------+------...
    99+
    2024-04-02
  • 从MySQL全库备份中恢复某个库和某张表
    从MySQL全库备份中恢复某个库和某张表 一、全库备份-A [root@mha2 backup]#mysqldump -uroot -p123456 --default-character-se...
    99+
    2024-04-02
  • 数据库备份与恢复
    数据库备份与恢复 一、物理备份和逻辑备份二、mysqldump实现逻辑备份2.1 备份一个数据库2.2 备份全部数据库2.3 备份部分数据库2.4 备份部分表2.5 备份单表的部分数据2.6 排除某些表的备份2.7 只备份结构或只备...
    99+
    2023-08-18
    数据库 mysql sql
  • Mongo 备份数据库和恢复数据库
    备份 mongodump -h : -d -o 恢复 mongorestore -h : -d hostname: ip地址 (公网IP地址) port: 端口号(mongo默认端口27017) dbna...
    99+
    2020-04-11
    Mongo 备份数据库和恢复数据库
  • Mysql数据库之备份和恢复
     一、为什么要数据备份?   备份的主要目的是灾难恢复。 在生产环境中,数据的安全性至关重要。 任何数据的丢失都可能产生严重的后果。 造成数据丢失的原因: 程序错误人为,操作错误,运算错误,磁盘故障灾难(如火灾、地震)和盗窃. 二、...
    99+
    2023-09-15
    数据库 mysql
  • MySQL数据库的备份与恢复
    一、数据备份的重要性 备份的主要目的是灾难恢复。 在生产环境中,数据的安全性至关重要。 任何数据的丢失都可能产生严重的后果。 造成数据丢失的原因: 程序错误人为操作错误运算错误磁盘故障灾难(如火灾、地震)和盗窃 二、数据库备份...
    99+
    2023-10-27
    数据库
  • mysql怎么恢复备份数据库
    要恢复MySQL备份数据库,可以按照以下步骤进行操作: 将备份文件复制到MySQL数据库服务器上的合适位置。确保备份文件的权限设...
    99+
    2024-04-02
  • mysql中如何通过备份恢复搭建从库
    这篇文章主要介绍了mysql中如何通过备份恢复搭建从库,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 MYSQ...
    99+
    2024-04-02
  • SQLServer数据库之备份和恢复数据库
    目录1. 概述2. 备份类型3. 恢复模式3.1 简单恢复模式3.2 完全恢复模式和大容量日志恢复模式4. 备份数据库5. 恢复数据库1. 概述 在一些对数据可靠性要求很高的行业,若...
    99+
    2023-03-23
    数据库的备份方法 数据库的恢复方式
  • Sqlite—数据库备份与恢复
    数据库备份 例如:备份 /www/wwwroot 下面的 task.db 数据库 进入数据库 [root@localhost ~]# sqlite3 /www/wwwroot/task.db 备份数据库 sqlite> .output...
    99+
    2016-10-11
    Sqlite—数据库备份与恢复
  • Redis数据库备份与恢复
    Redis所有数据都是保存在内存中。下面讲述三种备份方式:1.定期地通过异步方式保存到磁盘上,该方式称为半持久化模式。1)半持久化RDB模式也是Redis备份默认方式,是通过快照完成的,当满足redis.c...
    99+
    2024-04-02
  • 达梦数据库备份恢复
    1 备份恢复概述   DM7 数据库中的数据存储在数据库的物理数据文件中,数据文件按照页、簇和段的方式进行管理,数据页是最小的数据存储单元。任何一个对 DM7 数据库的操作,归根结底都是对某个数据文件页...
    99+
    2024-04-02
  • mysql数据备份-主从同步恢复
    【1】数据库备份和恢复 1、xtrabackup-物理备份 全量备份主库数据:xtrabackup --backup --user=root --password=xxx --port=3306 --...
    99+
    2023-09-14
    mysql 数据库 服务器
  • MySQL中怎么备份和恢复数据库
    MySQL中可以通过mysqldump命令来备份数据库,通过source命令来恢复数据库。 备份数据库: 打开命令行工具,输入以下...
    99+
    2024-04-09
    MySQL 数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作