如何计算字节排序分区程序的令牌



我正在测试具有不同配置的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])

但是所有负载都发生在节点 2 和节点 3 上。

为什么这些令牌不起作用?我应该如何解决它们?

首先,您应该在每个节点上运行清理,以确保您不会看到节点不再负责的额外数据。

完成此操作后,您可以使用 getRangeKeySample JMX 方法来获取节点上的密钥示例。 然后,可以将其令牌调整为一个值,该值在必要时将适当数量的密钥移动到其邻居。

也就是说:您几乎肯定应该改用RandomPartitioner来避免此问题。 我已经在这样的文章中解释了如何在分区键中使用集群来执行您可能想使用 BOP 的排序类型。

相关内容

  • 没有找到相关文章

最新更新