Only emit query metrics for uncached queries.

This commit is contained in:
Gian Merlino 2014-08-04 16:42:38 -07:00
parent b5ecf000ad
commit 6c8222788b
1 changed files with 22 additions and 22 deletions

View File

@ -390,30 +390,30 @@ public class ServerManager implements QuerySegmentWalker
{ {
SpecificSegmentSpec segmentSpec = new SpecificSegmentSpec(segmentDescriptor); SpecificSegmentSpec segmentSpec = new SpecificSegmentSpec(segmentDescriptor);
return new SpecificSegmentQueryRunner<T>( return new SpecificSegmentQueryRunner<T>(
new MetricsEmittingQueryRunner<T>( new BySegmentQueryRunner<T>(
emitter, adapter.getIdentifier(),
new Function<Query<T>, ServiceMetricEvent.Builder>() adapter.getDataInterval().getStart(),
{ new CachingQueryRunner<T>(
@Override
public ServiceMetricEvent.Builder apply(@Nullable final Query<T> input)
{
return toolChest.makeMetricBuilder(input);
}
},
new BySegmentQueryRunner<T>(
adapter.getIdentifier(), adapter.getIdentifier(),
adapter.getDataInterval().getStart(), segmentDescriptor,
new CachingQueryRunner<T>( objectMapper,
adapter.getIdentifier(), cache,
segmentDescriptor, toolChest,
objectMapper, new MetricsEmittingQueryRunner<T>(
cache, emitter,
toolChest, new Function<Query<T>, ServiceMetricEvent.Builder>()
new ReferenceCountingSegmentQueryRunner<T>(factory, adapter), {
cacheConfig @Override
) public ServiceMetricEvent.Builder apply(@Nullable final Query<T> input)
{
return toolChest.makeMetricBuilder(input);
}
},
new ReferenceCountingSegmentQueryRunner<T>(factory, adapter)
).withWaitMeasuredFromNow(),
cacheConfig
) )
).withWaitMeasuredFromNow(), ),
segmentSpec segmentSpec
); );
} }