prom/graphite-exporterGraphite Exporter是用于导出Graphite明文协议指标的工具,通过TCP和UDP接收数据,将点分隔的Graphite指标转换为带标签的Prometheus指标并暴露HTTP端点,供Prometheus采集。适用于现有Graphite监控系统向Prometheus迁移或集成,以及处理核心Prometheus导出器未覆盖的指标。
--graphite.sample-expiry调整shmake ./graphite_exporter
配置监控系统向9109端口发送Graphite数据,测试示例:
sh# TCP测试 echo "test_tcp 1234 $(date +%s)" | nc localhost 9109 # UDP测试 echo "test_udp 1234 $(date +%s)" | nc -u -w1 localhost 9109
指标可通过 http://localhost:9108/metrics 访问
支持Graphite带标签carbon格式,无效标签会被丢弃,graphite_tag_parse_failures计数器递增。默认配置标签优先于指标标签,如需使用指标标签可启用honor_labels。
注意:0.2.0版本后配置格式变更为statsd_exporter的YAML风格,旧配置需转换(见下方说明)
通过YAML文件定义指标映射规则,语法与statsd_exporter兼容(不支持timer_type相关特性)。未匹配规则的指标将转换为无标签Prometheus指标,非字母数字字符(除_和:)替换为_。启用--graphite.mapping-strict-match可仅保留匹配规则的指标。
示例配置:
yamlmappings: - match: test.dispatcher.*.*.* name: dispatcher_events_total labels: action: $2 job: test_dispatcher outcome: $3 processor: $1 - match: '*.signup.*.*' name: signup_events_total labels: job: ${1}_server outcome: $3 provider: $2 - match: 'servers\.(.*)\.networking\.subnetworks\.transmissions\.([a-z0-9-]+)\.(.*)' match_type: regex name: 'servers_networking_transmissions_${3}' labels: hostname: ${1} device: ${2}
转换效果:
test.dispatcher.FooProcessor.send.success → dispatcher_events_total{processor="FooProcessor", action="send", outcome="success", job="test_dispatcher"} foo_product.signup.***.failure → signup_events_total{provider="***", outcome="failure", job="foo_product_server"}
0.2.0前版本配置需通过statsd-exporter-convert转换:
sh# 安装转换工具 go get -u github.com/bakins/statsd-exporter-convert # 转换示例 statsd-exporter-convert old_config.conf > new_config.yaml
使用官方镜像prom/graphite-exporter部署:
bash# 拉取镜像 docker pull prom/graphite-exporter # 运行容器(挂载配置文件) docker run -d -p 9108:9108 -p 9109:9109 -p 9109:9109/udp \ -v ${PWD}/graphite_mapping.yaml:/tmp/graphite_mapping.yaml \ prom/graphite-exporter --graphite.mapping-config=/tmp/graphite_mapping.yaml
端口说明:
使用getool工具导入Graphite的Whisper数据:
sh# 查看帮助 getool create-blocks --help # 导入示例(指定块时长为8小时) getool create-blocks --block-duration=8h --input-dir=/path/to/whisper --output-dir=/path/to/tsdb
合并至现有Prometheus存储时,需启动Prometheus并添加--storage.tsdb.allow-overlapping-blocks标志。
不兼容Java客户端或Python客户端的Graphite桥,因数据模型转换会丢失信息且指标可能冲突。替代方案:
通过--web.config.file指定配置文件启用安全特性,格式详见exporter-toolkit文档。配置示例:
yamltls_config: cert_file: /etc/tls/cert.pem key_file: /etc/tls/key.pem basic_auth_users: admin: $2a$10$VQwZ... # bcrypt加密的密码
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务