首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何计算ByteOrderedPartitioner的令牌

如何计算ByteOrderedPartitioner的令牌
EN

Stack Overflow用户
提问于 2012-06-20 04:47:30
回答 1查看 1.4K关注 0票数 3

我正在测试具有不同配置的Cassandra集群的行为。其中之一使用ByteOrderedPartitioner沿着节点分发密钥。

数据模型是由多个行组成的,每个行都有一个整数(IntegerType)作为键,值从0到9999。我这样设置了一个10个节点的环:

代码语言:javascript
复制
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上进行复制。

为什么这些令牌不起作用?我该如何修复它们呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-06-20 08:56:58

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

完成后,您可以使用getRangeKeySample JMX方法来获取节点上的键的样本。然后,如有必要,可以将其标记调整为可将适当数量的关键点移动到其邻居的值。

也就是说:为了避免这个问题,您几乎肯定应该使用RandomPartitioner。我已经在像this这样的帖子中解释了如何在分区键中使用集群来进行排序,否则您可能会尝试使用BOP。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11109162

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档