Package com.codahale.metrics
Class InstrumentedExecutorService
java.lang.Object
com.codahale.metrics.InstrumentedExecutorService
- All Implemented Interfaces:
Executor
,ExecutorService
An
ExecutorService
that monitors the number of tasks submitted, running,
completed and also keeps a Timer
for the task duration.
It will register the metrics using the given (or auto-generated) name as classifier, e.g: "your-executor-service.submitted", "your-executor-service.running", etc.
-
Constructor Summary
ConstructorDescriptionInstrumentedExecutorService
(ExecutorService delegate, MetricRegistry registry) Wraps anExecutorService
uses an auto-generated default name.InstrumentedExecutorService
(ExecutorService delegate, MetricRegistry registry, String name) Wraps anExecutorService
with an explicit name. -
Method Summary
Modifier and TypeMethodDescriptionboolean
awaitTermination
(long l, TimeUnit timeUnit) void
invokeAll
(Collection<? extends Callable<T>> tasks) invokeAll
(Collection<? extends Callable<T>> tasks, long timeout, TimeUnit unit) <T> T
invokeAny
(Collection<? extends Callable<T>> tasks) <T> T
invokeAny
(Collection<? extends Callable<T>> tasks, long timeout, TimeUnit unit) boolean
boolean
void
shutdown()
Future<?>
<T> Future<T>
<T> Future<T>
-
Constructor Details
-
InstrumentedExecutorService
Wraps anExecutorService
uses an auto-generated default name.- Parameters:
delegate
-ExecutorService
to wrap.registry
-MetricRegistry
that will contain the metrics.
-
InstrumentedExecutorService
Wraps anExecutorService
with an explicit name.- Parameters:
delegate
-ExecutorService
to wrap.registry
-MetricRegistry
that will contain the metrics.name
- name for this executor service.
-
-
Method Details
-
execute
-
submit
- Specified by:
submit
in interfaceExecutorService
-
submit
- Specified by:
submit
in interfaceExecutorService
-
submit
- Specified by:
submit
in interfaceExecutorService
-
invokeAll
public <T> List<Future<T>> invokeAll(Collection<? extends Callable<T>> tasks) throws InterruptedException - Specified by:
invokeAll
in interfaceExecutorService
- Throws:
InterruptedException
-
invokeAll
public <T> List<Future<T>> invokeAll(Collection<? extends Callable<T>> tasks, long timeout, TimeUnit unit) throws InterruptedException - Specified by:
invokeAll
in interfaceExecutorService
- Throws:
InterruptedException
-
invokeAny
public <T> T invokeAny(Collection<? extends Callable<T>> tasks) throws ExecutionException, InterruptedException - Specified by:
invokeAny
in interfaceExecutorService
- Throws:
ExecutionException
InterruptedException
-
invokeAny
public <T> T invokeAny(Collection<? extends Callable<T>> tasks, long timeout, TimeUnit unit) throws ExecutionException, InterruptedException, TimeoutException - Specified by:
invokeAny
in interfaceExecutorService
- Throws:
ExecutionException
InterruptedException
TimeoutException
-
shutdown
public void shutdown()- Specified by:
shutdown
in interfaceExecutorService
-
shutdownNow
- Specified by:
shutdownNow
in interfaceExecutorService
-
isShutdown
public boolean isShutdown()- Specified by:
isShutdown
in interfaceExecutorService
-
isTerminated
public boolean isTerminated()- Specified by:
isTerminated
in interfaceExecutorService
-
awaitTermination
- Specified by:
awaitTermination
in interfaceExecutorService
- Throws:
InterruptedException
-