don't use thread local to aggregate string terms facet

This commit is contained in:
Shay Banon 2011-07-31 14:40:17 +03:00
parent 5e8a021405
commit 56b495534a
1 changed files with 5 additions and 10 deletions

View File

@ -19,11 +19,11 @@
package org.elasticsearch.search.facet.terms.strings; package org.elasticsearch.search.facet.terms.strings;
import org.elasticsearch.common.CacheRecycler;
import org.elasticsearch.common.collect.BoundedTreeSet; import org.elasticsearch.common.collect.BoundedTreeSet;
import org.elasticsearch.common.collect.ImmutableList; import org.elasticsearch.common.collect.ImmutableList;
import org.elasticsearch.common.io.stream.StreamInput; import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.common.io.stream.StreamOutput; import org.elasticsearch.common.io.stream.StreamOutput;
import org.elasticsearch.common.thread.ThreadLocals;
import org.elasticsearch.common.trove.iterator.TObjectIntIterator; import org.elasticsearch.common.trove.iterator.TObjectIntIterator;
import org.elasticsearch.common.trove.map.hash.TObjectIntHashMap; import org.elasticsearch.common.trove.map.hash.TObjectIntHashMap;
import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentBuilder;
@ -188,20 +188,12 @@ public class InternalStringTermsFacet extends InternalTermsFacet {
return otherCount(); return otherCount();
} }
private static ThreadLocal<ThreadLocals.CleanableValue<TObjectIntHashMap<String>>> aggregateCache = new ThreadLocal<ThreadLocals.CleanableValue<TObjectIntHashMap<String>>>() {
@Override protected ThreadLocals.CleanableValue<TObjectIntHashMap<String>> initialValue() {
return new ThreadLocals.CleanableValue<TObjectIntHashMap<String>>(new TObjectIntHashMap<String>());
}
};
@Override public Facet reduce(String name, List<Facet> facets) { @Override public Facet reduce(String name, List<Facet> facets) {
if (facets.size() == 1) { if (facets.size() == 1) {
return facets.get(0); return facets.get(0);
} }
InternalStringTermsFacet first = (InternalStringTermsFacet) facets.get(0); InternalStringTermsFacet first = (InternalStringTermsFacet) facets.get(0);
TObjectIntHashMap<String> aggregated = aggregateCache.get().get(); TObjectIntHashMap<String> aggregated = CacheRecycler.popObjectIntMap();
aggregated.clear();
long missing = 0; long missing = 0;
long total = 0; long total = 0;
for (Facet facet : facets) { for (Facet facet : facets) {
@ -221,6 +213,9 @@ public class InternalStringTermsFacet extends InternalTermsFacet {
first.entries = ordered; first.entries = ordered;
first.missing = missing; first.missing = missing;
first.total = total; first.total = total;
CacheRecycler.pushObjectIntMap(aggregated);
return first; return first;
} }