是否可以在日志中公开Dropwizard指标

时间:2018-10-02 21:11:08

标签: java mapping dropwizard metrics

我正在尝试在应用程序中设置日志记录方案,以显示Dropwizard中的线程计数。当转到8081上的管理端口时,可以看到Dropwizard为应用程序提供的指标。例如,在“仪表”下,您可以看到jvm.memory.total.used及其值。我想设置slf4j日志以在某些请求中显示该信息。因此,例如,我的GET请求可能看起来像这样:

@GET
@TIME
@Produces(MediaType.Application_JSON)
public List<String> getNames {
    List<String> nameList = dao.getList();
    log.info("Memory used: {}", /*the value for jvm.memory.total.used*/)
    return nameList;
}

但是,在以这种方式公开指标方面,我找不到很多东西。这可能吗?如果可以,这样做是否可行?

更新:

我设法在GET服务中公开胎面状态的度量,因此现在我正在尝试将结果放入日志语句中。到目前为止,这是我的代码:

@Path("metrics")
@Produces(MediaType.APPLICATION_JSON)
public class GetStuff {
    private static final Logger log = LoggerFactory.getLogger(GetStuff.class);

    @GET
    @Path("/metrics")
    public MetricRegistry provideMetrics() {
        MetricRegistry metrics = new MetricRegistry();
        metrics.register("jvm.threads", new ThreadStatesGaugeSet());

        log.info("JVM Thread Count: {}", metrics.getGauges().get("jvm.threads.count"));
        return metrics;
    }
}

我已经确认这将返回指标,所以现在我试图使log语句正常工作,并打印出该量规的值。我现在的主要问题是日志似乎正在打印出getGauges映射中的值的地址,而不是与键关联的值。更具体地说,我得到的是这样的值:

JVM Thread Count: com.codahale.metrics.jvm.ThreadStatesGaugeSet$2@129e489

有人知道我该如何解决,这样我才能获得实际价值?

编辑:我打开了与此问题相关的另一个问题,here

1 个答案:

答案 0 :(得分:0)

我设法使它正常工作。大多数过程记录在我对问题的编辑中,但这是最终代码:

@Path("metrics")
@Produces(MediaType.APPLICATION_JSON)
public class GetStuff {
    private static final Logger log = LoggerFactory.getLogger(GetStuff.class);

    @GET
    @Path("/metrics")
    public MetricRegistry provideMetrics() {
        MetricRegistry metrics = new MetricRegistry();
        metrics.register("jvm.threads", new ThreadStatesGaugeSet());

        log.info("JVM Thread Count: {}", metrics.getGauges().get("jvm.threads.count").getValue);
        return metrics;
    }
}

我忘了使用getValue()来获取log语句的值,这很好地解决了我从getGauges映射中打印地址而不是实际值的问题。