【问题标题】:How to enable ExecutorServiceMetrics in SpringBoot 2.1.2?如何在 SpringBoot 2.1.2 中启用 ExecutorServiceMetrics?
【发布时间】:2019-10-04 05:19:13
【问题描述】:
【问题讨论】:
标签:
spring-boot
spring-boot-actuator
spring-micrometer
【解决方案1】:
这是我解决它的方法(在 kotlin 中):
@EnableAsync
@Configuration
class AsyncConfig(
private val taskExecutorBuilder: TaskExecutorBuilder,
private val meterRegistry: MeterRegistry) : AsyncConfigurer {
/**
* Add monitoring of executor using micrometer.
*/
override fun getAsyncExecutor(): Executor {
// create executor based on default spring-boot properties
val executor = taskExecutorBuilder.build()
// we need to initialize it before calling monitor
executor.initialize()
// monitor the executor (so it is available in metrics) (must be wrapped)
return ExecutorServiceMetrics.monitor(meterRegistry, executor.threadPoolExecutor, "AsyncExecutor", "async")
}
}
所以基本上:
- 使用自动连线的
TaskExecutorBuilder,因此执行器是根据spring.task.execution.* 属性构建的
- 将线程池执行程序包装在
ExecutorServiceMetrics(来自io.micrometer.core)中以获取指标
请注意,要使其正常工作,您必须返回已装饰的执行程序!
在此示例中,由于我给出了前缀 (async),因此可用的指标是:
- async.executor
- async.executor.active
- async.executor.completed
- async.executor.idle
- async.executor.pool.core
- async.executor.pool.max
- async.executor.pool.size
- async.executor.queue.remaining
- async.executor.queued
【解决方案2】:
我发现如果你想用 Spring Boot 锁定它,你必须手动完成。我正在使用 Spring Boot 2.2.9.RELEASE。
使用“applicationTaskExecutor”bean 创建一个 ExecutorServiceMetrics bean(这样,您可以获得之前配置的任何 bean 大小)。它会自动绑定。
类似:
@Bean
@ConditionalOnMissingBean
public ExecutorServiceMetrics executorServiceMetrics(@Qualifier("applicationTaskExecutor") ThreadPoolTaskExecutor applicationTaskExecutor) {
return new ExecutorServiceMetrics(applicationTaskExecutor.getThreadPoolExecutor(), "applicationTaskExecutor",
Collections.emptyList());
}
【解决方案3】:
我能够在 Spring Boot 2.1.2.RELEASE 应用程序中获得 ExecutorServiceMetrics 报告指标,并且只需创建一个受监控的 ExecutorService bean 即可。我无需向我的 application.yml 或 application.properties 添加任何内容即可完成这项工作。
例子:
@Configuration
public class ExecutorConfig {
@Bean
public ExecutorService executorService(final MeterRegistry registry) {
return ExecutorServiceMetrics.monitor(registry, Executors.newFixedThreadPool(20), "my executor", Tags.of("key", "value"));
}
}
然后,只需将您的 executorService bean 连接到您的组件并将任务提交到该 executorService bean。