问题描述
我正在尝试使用 Micrometer 在我的 Java 应用程序中记录信息。
我的应用程序主目录中有 Micrometer 注册表初始化如下:
MeterRegistry registry = new SimpleMeterRegistry();
我有一个 CountedObject 类,它有一个 int id 和一个对 注册表 的引用。
在我的班级 CountedObject 中,我有一个名为 timedFunction() 的方法,如下所示:
@Timed(value = "myTimer")
public void timedFunction() {
try {
int sleepTime = new Random().nextInt(5) + 1;
Thread.sleep(sleepTime * 1000L);
} catch (InterruptedException e) {}
System.out.println("timedFunction");
}
还有一个名为timedFunction()的方法如下:
public void timeConsumingFunction() {
LongTaskTimer longTaskTimer = AppMetrics.getInstance().getLongTaskTimer("longTaskTimer1");
Sample task = longTaskTimer.start();
try {
int sleepTime = new Random().nextInt(5) + 1;
Thread.sleep(sleepTime * 1000L);
} catch (InterruptedException e) {}
System.out.println("timeConsumingFunction() for object-" + id + " took: " + task.duration(TimeUnit.SECONDS));
task.stop();
}
在我的应用程序中,我创建了一个对象 CountedObject 并运行这两种方法。
然后我运行以下命令来打印所有指标信息:
List<Meter> meters = registry.getMeters();
for (Meter meter : meters) {
System.out.println(meter.getId());
for (Measurement measurement : meter.measure()) {
System.out.println(measurement.getStatistic() + " : " + measurement.getValue());
}
System.out.println("\n");
}
我只在指标中找到了 "longTaskTimer1" 而在注释方法中使用的 myTimer 不存在。如何使用此 @Timed 注释以及如何将其链接到我的应用程序的寄存器
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)