一、动机
因为项目上用到了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。