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 / 问题 / 403104
Accepted
Oneiroi
Oneiroi
Asked: 2012-06-29 07:25:25 +0800 CST2012-06-29 07:25:25 +0800 CST 2012-06-29 07:25:25 +0800 CST

Percona XtraDB Cluster 节点恢复

  • 772

我一直在审查 XtraDB 集群,并使用 4 个实例在 Openstack 上生成了一个 PoC 环境,这在我的弹性测试中失败了。

根据 pxc 文档:http ://www.percona.com/doc/percona-xtradb-cluster/howtos/virt_sandbox.html涵盖了 3 节点安装,我选择了第 4 个。

  1. 初始设置完成数据加载测试通过,所有节点使用 1.6GB 测试 sql 文件同步更新以加载数据库。
  2. 节点的故障和恢复开始,此测试需要停止节点上的 mysql 服务,创建并随后删除数据库以测试幸存的节点复制,并启动已关闭的节点以重新同步。
    1. 这适用于节点 4、3、2。
    2. 根据 pxc 文档,Node1 本质上是一个控制器,不会重新加入集群。

所以我的问题如下:

  1. 如果幸存节点已将数据写入它们,如何使控制器节点返回服务
  2. 以4个节点为参考,有没有办法去掉node1这个单点故障?(如果一个幸存的节点在控制器(node1)关闭/不同步的情况下重新启动,该节点也将失败)。
percona-xtradb-cluster percona xtradb
  • 3 3 个回答
  • 5205 Views

3 个回答

  • Voted
  1. Best Answer
    Peter Boros
    2012-07-06T11:33:54+08:002012-07-06T11:33:54+08:00

    根据您在节点一上的症状,您正在使用

    wsrep_cluster_address=gcomm:// 
    

    在你的配置文件中,这意味着节点将启动一个新的集群。您可以通过 wsrep_cluster_size 变量在 node1 上为 1,在其他节点上为 3 来确认这一点。如果你想加入 node1 到你已经存在的集群,你应该指定

    wsrep_cluster_address=gcomm://(这里是一个正在运行的节点的ip)
    

    在这种情况下,node1 将重新加入集群。

    一些额外的想法:

    • 由于 PXC(Percona Xtradb Cluster)中的仲裁机制,不建议在 4 个节点上运行它。建议使用奇数个节点,这样在网络分裂的情况下,分裂集群的一部分将占多数。

    • 您可以在 [mysqld_safe] 部分中使用 wsrep_urls 而不是 wsrep_cluster_address。

    免责声明:我为 Percona 工作。

    • 6
  2. Oneiroi
    2012-06-29T08:16:34+08:002012-06-29T08:16:34+08:00

    对该问题的进一步研究似乎是一种可行的方法(暂时不接受此答案,以防有人以更好的设置回复):

    1. 循环设置
      1. 根据 pxc 文档,所有节点都从节点 1 同步
      2. 停止node2重新指向node3,启动node 2
      3. 停止node3重新指向node4,启动node 3
      4. 停止node1重新指向node2,启动node 1

    此设置似乎至少可以容忍任何节点因断开连接而丢失,并且可以毫无问题地恢复节点同步。

    • 1
  3. steve
    2013-04-07T02:07:52+08:002013-04-07T02:07:52+08:00

    如果 Mysql 无法启动,原因是损坏的数据库表。

    复制服务器正在执行的操作,并从已停止的服务器中为客户端数据库获取一份好的副本。

    它通过 nc 对 $MYSQLHOME 中的 db 文件进行 tars 处理。

    我们使用 scp 将好文件移动到位,然后通过启动坏服务器的 mysql 再次开始同步。

    • -3

相关问题

  • XtraBackup for SST with Xtradb 集群

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +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