Codahale Metrics:在普通Java中使用@Timed指标注释
我正在尝试使用codahale指标将指标添加到普通的Java应用程序中。我想使用@Timed注释,但我不清楚它使用哪个指标注册表,或者如何告诉它使用哪个指标注册表。该应用程序是一个普通的Java 8应用程序,使用Maven 3构建,没有Spring,没有Hibernate。
我无法在dropwizard文档中找到有关如何实现@Timed的任何文档:https://dropwizard.github.io/metrics/3.1.0/manual/
我添加了这些依赖项:
<dependency>
<groupId>io.dropwizard.metrics</groupId>
<artifactId>metrics-core</artifactId>
<version>3.1.0</version>
</dependency>
<dependency>
<groupId>com.codahale.metrics</groupId>
<artifactId>metrics-annotation</artifactId>
<version>3.0.2</version>
</dependency>
当我使用对计时器的程序调用时,我可以获得报告,因为我知道使用了哪个指标注册表:
static final MetricRegistry metrics = new MetricRegistry();
private void update() throws SQLException {
Timer.Context time = metrics.timer("domainobject.update").time();
try {
[...]
} finally {
time.stop();
}
}
但是当我使用更优雅的@Timed注释时,我不知道使用了哪个注册表,因此我无法创建报告器,这意味着我无法报告指标(我甚至不确定这是否真的做了什么):
@Timed(name = "domainobject.update")
private void update() throws SQLException {
[...]
}
请就如何使@Timed和其他指标注释在常规 Java 应用程序中正常工作提供建议。
附加信息:我发现这很奇怪的原因是我已经添加了龙目岛框架,并且@Slf4j注释确实有效。我在 maven pom 中添加了 Lombok 作为依赖项.xml:
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.14.8</version>
</dependency>
我可以使用@Sl4fj类注释将记录器添加到类中,而不会使成员变量混乱:
@Slf4j
public class App {
public void logsome(){
log.info("Hello there");
}
}
因此,如果只需添加依赖项即可实现这一点,我认为我只是缺少依赖项或配置来获得codahale@Timed注释工作,如上所述。
(顺便说一句,看看龙目岛,它会让你的生活更轻松:http://projectlombok.org/ )