AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 49571
Accepted
Alex Balashov
Alex Balashov
Asked: 2009-08-04 17:29:47 +0800 CST2009-08-04 17:29:47 +0800 CST 2009-08-04 17:29:47 +0800 CST

MySQL差异转储?其他恢复策略?

  • 772

是否可以在两个数据库之间,或者理想情况下,在数据库和该数据库的转储版本之间生成差异转储mysqldump?

这是我遇到的问题——我有一个 MySQL 的主动/被动 HA 镜像,实际数据库数据(物理 MyISAM 文件、索引等)位于共享 DRBD 镜像上。上周,主节点发生故障,DRBD 主节点从主节点转移到辅助节点,服务接管按预期发生。

当然,已将大量更改写入辅助副本的 DRBD 镜像版本,因此当主副本恢复时,它会接管 DRBD 卷,但双方都认为它们的一半“不同步”(即StandAlone)。

所以,现在我遇到了一种情况,数据库上发生了两组不同的事务:

  • 发生在主节点关闭并且数据正在写入辅助节点时发生的事情;

  • 自从主节点恢复并再次接管服务后发生的事情;他们从来没有同步!

DRBD 使我能够将镜像的“一半”(处于其当前分区状态)恢复为“主”修订版,但可以看出,任何一种方式都会导致我丢失数据。

哦,是的:没有复制,也没有本地事务日志,所以没有可重放的二进制日志。哎呀。 掌心

当然,每晚都有备份,所以我可以将数据库恢复到去年大约凌晨 2 点左右的任何状态。

我想我想要做的是恢复到现在在辅助“一半”上的数据库版本(即在主服务器关闭时发生的更改),然后尝试以某种方式应用从那时起的状态更改到累积在主数据库的“一半”上的数据库的当前状态。

问题是,如果不重放事务日志,我不知道如何去做。

见解赞赏,并在此先感谢!

linux mysql diff drbd
  • 2 2 个回答
  • 2477 Views

2 个回答

  • Voted
  1. Best Answer
    Karl Katzke
    2009-08-04T19:01:10+08:002009-08-04T19:01:10+08:00

    哎哟。糟糕的情况。我希望你现在已经打开了 binlogging...

    两个可能有用的工具:

    • MySQLdiff - 可能工作。
    • Maatkit - 先看看这个。我认为它实际上有一些旨在帮助解决脑裂问题的工具。
    • 2
  2. Nathacof
    2009-08-04T18:38:31+08:002009-08-04T18:38:31+08:00

    您不需要重播故障服务器上的数据。这种情况称为脑裂,你需要告诉 DRBD 你想让它做什么。

    http://www.drbd.org/users-guide/s-resolve-split-brain.html

    编辑:没有意识到你说初级恢复在线......不太确定。二进制日志应该包含服务器执行的所有事务的记录。

    编辑(Take 2):我需要在发布之前做一个笔记来阅读整个问题...... :( 抱歉

    • 0

相关问题

  • 多操作系统环境的首选电子邮件客户端

  • 你最喜欢的 Linux 发行版是什么?[关闭]

  • 更改 PHP 的默认配置设置?

  • 保护新的 Ubuntu 服务器 [关闭]

  • (软)Ubuntu 7.10 上的 RAID 6,我应该迁移到 8.10 吗?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve