我正在测试具有不同配置的Cassandra集群的行为。其中之一使用ByteOrderedPartitioner沿着节点分发密钥。
数据模型是由多个行组成的,每个行都有一个整数(IntegerType)作为键,值从0到9999。我这样设置了一个10个节点的环:
Address Rack Status State Owns Token
Token(bytes[0900])
node1 Up Normal 5.14 MB 10.00% Token(bytes[00])
node2 Up Normal 377.42 MB 10.00% Token(bytes[0100])
node3 Up Normal 373.06 MB 10.00% Token(bytes[0200])
node4 Up Normal 966.15 KB 10.00% Token(bytes[0300])
node5 Up Normal 953.4 KB 10.00% Token(bytes[0400])
node6 Up Normal 953.26 KB 10.00% Token(bytes[0500])
node7 Up Normal 944.54 KB 10.00% Token(bytes[0600])
node8 Up Normal 953.4 KB 10.00% Token(bytes[0700])
node9 Up Normal 962.42 KB 10.00% Token(bytes[0800])
node10 Up Normal 961.31 KB 10.00% Token(bytes[0900])但是所有的负载都在node2和node3上进行复制。
为什么这些令牌不起作用?我该如何修复它们呢?
发布于 2012-06-20 08:56:58
首先,您应该在每个节点上运行cleanup,以确保在启动后不会看到该节点不再负责的额外数据。
完成后,您可以使用getRangeKeySample JMX方法来获取节点上的键的样本。然后,如有必要,可以将其标记调整为可将适当数量的关键点移动到其邻居的值。
也就是说:为了避免这个问题,您几乎肯定应该使用RandomPartitioner。我已经在像this这样的帖子中解释了如何在分区键中使用集群来进行排序,否则您可能会尝试使用BOP。
https://stackoverflow.com/questions/11109162
复制相似问题