我有一个带注释的方法,如下所示:
@Timed(value="timed", extraTags={"account", Account.getById(@PathVariable("id")}
public Info getInfo(@PathVariable("id") String id) {
return Info.getById(id);
}
上面的方法当然行不通。希望您能看到我正在尝试做的事情。在给定路径上的 id 的情况下,将帐户标记设置为 Account.getById() 返回的值的正确语法是什么?
最佳答案
我不相信您能够使用 @Timed
注释来完成您正在做的事情,但您可以手动为该方法计时并执行您想要的操作。这是一个例子:
.
.
.
@Autowired MeterRegistry meterRegistry;
.
.
.
public Info getInfo(@PathVariable("id") String id) {
final Sample sample = Timer.start(meterRegistry);
final Info info = Info.getById(id);
sample.stop(Timer.builder("timed")
.tag("account", Account.getById(id)
.register(meterRegistry));
return info;
}
关于java - @TImed 带有 extraTags 和 @PathVariable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55932486/