gpt4 book ai didi

mysql - 从 Slave 快照的 Master 和 Slaves 故障转移

转载 作者:行者123 更新时间:2023-11-30 23:40:34 25 4
gpt4 key购买 nike

我计划在一台主服务器和几台从服务器上使用 MySQL 设置服务器。我会在其中一个从服务器上定期执行数据 EBS 的一致备份服务器(我总是会先停止数据库,然后在完成后重新启动它)。

从站故障转移
如果其中一个slave发生故障,我将启动新实例并根据最新的slave快照挂载EBS作为新的数据磁盘。在这种情况下,master 随时可用。所以这就是我认为我应该做的:

0) 确保服务器使用唯一的 server_id1) 从站停止;
2) 重置奴隶;
3) 启动奴隶;
4)重启mysql?

够了吗?

主节点故障转移出于简单性和一致性的原因,我不想将其中一个奴隶提升为主人。我更喜欢从头开始创建新的主人。问题是快照来自从站,我想将它用作主站。这是我认为在使用基于从属快照的磁盘创建新实例后我应该做的:

1) 停止奴隶;
2) 重置主机;
3) 重启mysql
4) 将弹性 IP 关联到新的主数据库(失败的主数据库使用相同的 IP),因此从数据库将能够再次连接。

这个过程是否正确?我现在应该如何处理奴隶?奴隶可以领先于主人,因为主人是从几个小时前的快照中恢复的。这是问题吗?也有可能从用于恢复主服务器的同一快照重新创建所有从服务器。然后他们将与主人处于相同的位置。但这可能很复杂,而且如果不停机就不可能继续进行。有什么更好的方法吗?

非常感谢您!

注意:我不介意自最新快照以来丢失的交易。我正在使用 Mysql 5.1.41。

最佳答案

我用来恢复不同步服务器的两种方法是:

  • 将转储从“好”服务器重新导入“坏”服务器。在你的情况下,它将从一个好的奴隶导入一个转储到坏的主人。
  • 在受影响的服务器上运行 Navicat 等程序。 Navicat 有一个功能允许两个表之间的数据同步(单向、双向等),以便重新添加任何丢失的记录。

在这两种方法中,您都需要停止 master 并重置 master。重置从站也会有所帮助。

关于mysql - 从 Slave 快照的 Master 和 Slaves 故障转移,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3485196/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com