0

GridCache.keySet().primarySize()、および.size()そのノードの情報のみを返します。

これらの情報をクラスター全体で取得するにはどうすればよいですか?

クラスター全体のスキャンは「機能」しますが、必要なのは値ではなくキーまたはカウントだけです。

問題は、インデックス付きフィールドに基づいて検索したい場合に SQL クエリが機能することですが、グリッド キャッシュ エントリ キー自体に基づいて検索することはできません。

機能しますが、エレガントでパフォーマンスにはほど遠い私の回避策は次のとおりです。

Set<String> ruleIds = FluentIterable.from(cache.queries().createSqlFieldsQuery("SELECT property FROM YagoRule").execute().get())
        .<String>transform((it) -> (String) it.iterator().next()).toSet();

これには、キーがフィールドの 1 つと同じである必要があり、パフォーマンス上の理由からフィールドにインデックスを付ける必要があります。

4

1 に答える 1

1

GridGain (6.2.0) の次のリリースにはglobalSize()globalPrimarySize()クラスターにサイズを要求するメソッドが含まれます。

今のところ、次のコードを使用できます。

// 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;
于 2014-07-06T02:27:36.237 に答える