首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何获得整个keySet集群的keySet()和size()?

如何获得整个keySet集群的keySet()和size()?
EN

Stack Overflow用户
提问于 2014-07-05 12:28:53
回答 1查看 138关注 0票数 0

GridCache.keySet().primarySize().size()只返回该节点的信息。

除了整个集群之外,我如何获取这些信息?

扫描整个集群“有效”,但我所需要的只是键或计数,而不是值。

问题是,如果我想要基于索引字段查找,则SQL查询可以工作,但无法根据网格缓存条目键本身找到。

我的解决办法是有效的,但远远没有优雅和表演性:

代码语言:javascript
复制
Set<String> ruleIds = FluentIterable.from(cache.queries().createSqlFieldsQuery("SELECT property FROM YagoRule").execute().get())
        .<String>transform((it) -> (String) it.iterator().next()).toSet();

这要求键与字段中的一个相同,而且由于性能原因,需要对字段进行索引。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-07-06 02:27:36

GridGain的下一个版本(6.2.0)将有globalSize()globalPrimarySize()方法,它们将询问集群的大小。

现在,您可以使用以下代码:

代码语言:javascript
复制
// Only grab nodes on which cache "mycache" is started.
GridCompute compute = grid.forCache("mycache").compute();

Collection<Integer> res = compute.broadcast(
    // This code will execute on every caching node.
    new GridCallable<Integer>() {
         @Override public Integer call() {
             return grid.cache("mycache").size();
         }
    }
).get();

int sum = 0;

for (Integer i : res)
    sum += i;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24586449

复制
相关文章

相似问题

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