如何在 Java 应用程序中在 Spring 之外使用 Micrometer @Timed 注释

问题描述

我正在尝试使用 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 (将#修改为@)