【问题标题】:scrape with PrometheusMeterRegistry用 PrometheusMeterRegistry 刮擦
【发布时间】:2021-09-06 23:04:16
【问题描述】:

我有以下 servlet:

@Servlet(\path : String -> path.matches("/metrics"))
class MetricsServlet_De extends HttpServlet {
  private var prometheusMeterRegistry : PrometheusMeterRegistry

  override function init() {
    configureMetrics()
  }

  protected override function doGet(request : HttpServletRequest, response : HttpServletResponse) {
    response.ContentType = TextFormat.CONTENT_TYPE_004
    response.setStatus(HttpServletResponse.SC_OK)

    prometheusMeterRegistry.scrape(response.Writer)
  }

  
  private function configureMetrics() : PrometheusMeterRegistry {
    prometheusMeterRegistry = new PrometheusMeterRegistry(PrometheusConfig.DEFAULT);
    new ClassLoaderMetrics().bindTo(prometheusMeterRegistry)
    new JvmMemoryMetrics().bindTo(prometheusMeterRegistry)
    new JvmGcMetrics().bindTo(prometheusMeterRegistry)
    new ProcessorMetrics().bindTo(prometheusMeterRegistry)
    new JvmThreadMetrics().bindTo(prometheusMeterRegistry)

    var toDoubleFunction : ToDoubleFunction<GameMetrics> = \status -> status.GameFinished
    Gauge.builder("game_status", new GameMetrics(), toDoubleFunction)
        .description("Return Game status")
        .register(prometheusMeterRegistry)

    return prometheusMeterRegistry
  }


}

第一次调用 Servlet 时,会调用 GameMetrics.GameFinished() 并正确显示一个值。 对于所有对 servlet GameMetrics.GameFinished() 的后续调用,不再调用并返回 NaN。

我不知道我做错了什么。

最好的问候

【问题讨论】:

    标签: prometheus servlet-3.0 micrometer prometheus-java


    【解决方案1】:

    尝试保留对您在 Gauges 中用作状态对象的实例的引用(例如:私有 final 字段)(例如:GameMetrics)。

    Gauges 使用WeakReference 来引用它们的状态对象,这不会阻止它们被 GC 收集。因此,我认为在您的情况下,GC 会收集 GameMetrics 实例,因此它将为空,请参阅文档:https://micrometer.io/docs/concepts#_why_is_my_gauge_reporting_nan_or_disappearing

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-01-09
      • 2014-08-10
      • 2021-05-06
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多