17

我有一个 3 节点 cassandra 集群,复制因子为 2。节点运行 dsc1.2.3 或 dsc1.2.4。每个节点的 num_token 值为 256,并注释了 initial_token。这个 3 节点集群是完美平衡的,即每个节点拥有大约 30% 的数据。

其中一个节点崩溃了,所以我启动了一个新节点,nodetool 删除了已经崩溃的节点。新节点已添加到集群中,但两个较旧的节点现在拥有大部分数据(47.0% 和 52.3%),而新节点只有 0.7% 的数据。

nodetool status 的输出是

Datacenter: xx-xxxx
===================
Status=Up/Down
|/ State=Normal/Leaving/Joining/Moving
--  Address           Load       Tokens  Owns   Host ID                               Rack
UN  10.xxx.xxx.xxx    649.78 MB  256     47.0%  ba3534b3-3d9f-4db7-844d-39a8f98618f1  1c
UN  10.xxx.xxx.xxx    643.11 MB  256     52.3%  562f7c3f-986a-4ba6-bfda-22a10e384960  1a
UN  10.xxx.xxx.xxx    6.84 MB    256     0.7%   5ba6aff7-79d2-4d62-b5b0-c5c67f1e1791  1c

我如何平衡这个集群?

4

2 回答 2

6

您没有提到在新节点上运行修复,如果您确实还没有这样做,这可能是您在新节点上缺少数据的原因。

在您运行 nodetool repair 之前,新节点将只保存写入它的新数据或读取修复拉入的数据。使用 vnodes,如果我正确理解 vnodes,您通常不需要重新平衡,但我个人还没有开始使用 vnodes,所以我可能错了。

于 2013-05-03T16:19:12.250 回答
4

看起来您的新节点尚未启动。你添加auto_bootstrap=true到你的 cassandra.yaml 了吗?

如果您不想引导,您可以nodetool repair在新节点上运行,然后nodetool cleanup在另外两个节点上运行,直到分配公平。

于 2015-04-29T03:34:03.377 回答