如果,发现很多开源组件的普罗米修斯指标都是通过外挂 exporter 程序的形式暴露出来的,例如:consul-exporter,rocketmq-exporter,redis-exporter 等等,这样做有什么好处吗?出于性能考虑?
1
weijancc 2023-12-08 15:10:42 +08:00
prometheus 是主动请求 http 接口获取指标的, 你用 prometheus 那它的组件就必须是 exporter 形式
|
2
hzj629206717 2023-12-08 15:36:01 +08:00
因为应用的指标输出不是 Prometheus 的协议和格式,需要一个 exporter 来适配。
(那你可能要问了,为什么应用不原生支持 Prometheus 采集? Up to the author's decision.) |
3
deorth 2023-12-08 15:36:59 +08:00 via Android
你可以二开原应用,把这个功能加上去
|
4
AuroraTwinkle OP @hzj629206717 嗯嗯,比较好奇不原生集成 Prometheus 的考虑是不是怕影响性能?
|
5
AuroraTwinkle OP @weijancc 嗯嗯,我更想问的是,为啥不集成到应用代码里,而是外挂 exporter 的形式
|
6
AuroraTwinkle OP @deorth 可以的,主要是想了解下用外挂 exporter 而不是原生集成的原因
|
7
dextercai 2023-12-08 16:59:27 +08:00
Prometheus Pull 的这种形式需要暴露 HTTP 端点,但实现指标观测并不一定完全需要 Prometheus 。
观测组件有很多,比如结合 OpenTelemetry 生态,可以主动推送给 Prometheus ,或者推给 ElasticAPM 。 |
8
AuroraTwinkle OP @dextercai 多谢指点
|
9
julyclyde 2023-12-09 18:21:36 +08:00
为什么 exporter 格式:
大概是 prometheus 已经成为事实上的标准了 不选这标准的,大概都是要在企业内评职称的 为什么外挂: 应该是被监控的软件本身不支持且懒得支持 http 协议吧? |