一、动机
因为项目上用到了node_exporter,后期可能需要做些定制化,所以简单的看了下源码。在这里简单记录一下"/metrics"请求中的关键调用。
二、源码版本
node_exproter:1.13.0
client_golang:release-1.11
三、关键调用
node_exporter的main函数里注册了“/metrics”的处理函数。所有pull metrics请求都通过newHandler来处理。
http.Handle(*metricsPath, newHandler(!*disableExporterMetrics, *maxRequests, logger))
整个调用顺序大致如下:
1、newHandler函数中调用handler结构体的innerHandler方法
2、在innerHandler方法中最重要的处理是调用promhttp包的HandlerFor函数。promhttp是client_golang的一个包。
3、HandlerFor函数中实际定义HandlerFunc函数,这是用来响应“/metrics”请求的具体处理。HandlerFunc中调用了Gatherer接口的Gather方法。Registry结构体实现了Gatherer接口。
4、Registry结构体的Gather方法中调用了Collector接口的Collect方法。NodeCollector结构体实现了Collector接口。
5、NodeCollector结构体的Collect方法中通过遍历所有注册的collector并调用这个collector的Update方法来获取相关指标的最新数据。
传入Collect方法的chan是在Registry结构体的Gather方法中初始化的。Collect方法通过这个chan将获取的数据传回Gather方法进行解析处理。Gather方法返回解析后的所有指标数据,这些数据在HandlerFor函数以text格式写入到httpresponse。
本文详细描述了node_exporter1.13.0版本中处理/metrics请求的关键步骤,涉及newHandler、promhttp、HandlerFor、Gatherer、Collector和NodeCollector等核心组件的调用过程。
5319

被折叠的 条评论
为什么被折叠?



