Golang 自监控指标接口
Golang 插件自监控接口
LoongCollector 提供了指标接口,可以方便地为插件增加一些自监控指标,目前支持Counter,Gauge,String,Latency等类型。
接口:
https://github.com/alibaba/loongcollector/blob/main/pkg/pipeline/self_metric.go
实现:
https://github.com/alibaba/loongcollector/blob/main/pkg/helper/self_metrics_vector_imp.go
用户使用时需要引入pkg/helper包:
创建指标
指标必须先定义后使用,在插件的结构体内声明具体指标。
创建指标时,需要将其注册到 LoongCollector Context 的 MetricRecord 中,以便 LoongCollector 能够采集上报数据,在插件的Init方法中,调用context 的 GetMetricRecord()方法来获取MetricRecord,然后调用helper.NewXXXMetricAndRegister函数去注册一个指标,例如:
用户在声明一个Metric时可以还额外注入一些插件级别的静态Label,这是一个可选参数,例如flusher_http就把RemoteURL等配置进行上报:
指标打点
不同类型的指标有不同的打点方法,直接调用对应Metric类型的方法即可。 Counter:
Latency:
StringMetric:
指标上报
LoongCollector 会自动采集所有注册的指标,默认采集间隔为60s,然后通过default_flusher上报,数据格式为LogGroup,格式如下:
一组LogGroup中会有多条Log,每一条Log都对应一条指标,其中{"Key":"__name__","Value":"http_flusher_matched_events"}
是一个特殊的Label,代表指标的名字。
高级功能
动态Label
和Prometheus SDK类似,LoongCollector 也允许用户在自监控时上报可变Label,对于这些带可变Label的指标集合,LoongCollector 称之为MetricVector, MetricVector同样也支持上述的指标类型,因此把上面的Metric看作是MetricVector不带动态Label的特殊实现。 用例:
声明并注册MetricVector时,可以使用helper.NewXXXMetricVectorAndRegister方法, 需要将其带有哪些动态Label的Name也进行声明:
打点时通过WithLabels API传入动态Label的值,拿到一个Metric对象,然后进行打点:
示例
可以参考内置的一些插件:
http flusher插件: https://github.com/alibaba/loongcollector/blob/main/plugins/flusher/http/flusher_http.go