Fluent Bit
Fluent Bit 是一个快速且轻量级的遥测代理,用于 Linux、macOS、Windows 和 BSD 系列操作系统的日志、指标和跟踪。Fluent Bit 专注于性能,允许从不同来源收集和处理遥测数据而不增加复杂性。
你可以将 Fluent Bit 数据转发到 GreptimeDB。本文档介绍如何配置 Fluent Bit 以将日志、指标和跟踪发送到 GreptimeDB。
Http
使用 Fluent Bit 的 HTTP 输出插件,你可以将日志发送到 GreptimeDB。Http 接口目前支持日志的写入。 在配置 Fluent Bit 之前,请确保你已经了解日志写入流程和如何使用 pipelines。
[OUTPUT]
Name http
Match *
Host greptimedb
Port 4000
Uri /v1/ingest?db=public&table=your_table&pipeline_name=greptime_identity
Format json
Json_date_key scrape_timestamp
Json_date_format iso8601
compress gzip
http_User <username>
http_Passwd <password>
uri: 发送日志的端点。format: 日志的格式,需要是json。json_date_key: JSON 对象中包含时间戳的键。json_date_format: 时间戳的格式。compress: 使用的压缩方法,例如gzip。header: 发送请求时的头部信息,例如用于认证的Authorization。如果 没有,不要增加 Authorization 头部。http_user和http_passwd: GreptimeDB 的 认证凭据。
在 uri 参数中:
db是你要写入日志的数据库名称。table是你要写入日志的表名称。pipeline_name是你要用于处理日志的管道名称。
OpenTelemetry
GreptimeDB 也可以配置为 OpenTelemetry 收集器。使用 Fluent Bit 的 OpenTelemetry 输出插件,你可以将指标、日志和跟踪发送到 GreptimeDB。
[OUTPUT]
Name opentelemetry
Match *
Host 127.0.0.1
Port 4000
Metrics_uri /v1/otlp/v1/metrics
Logs_uri /v1/otlp/v1/logs
Traces_uri /v1/otlp/v1/traces
Log_response_payload True
Tls Off
Tls.verify Off
Metrics_uri,Logs_uri, 和Traces_uri: 发送指标、日志和跟踪的端点。
我们建议不要在一个 output 同时写入 metrics log 和 trace,因为我们的写入接口它们各自有一些特殊的 header 选项用于指定一些参数,我们建议一个为 metrics log 和 trace 单独创建一个 opentelemetry output 例如:
# Only for metrics
[OUTPUT]
Name opentelemetry
Alias opentelemetry_metrics
Match *
Host 127.0.0.1
Port 4000
Metrics_uri /v1/otlp/v1/metrics
Log_response_payload True
Tls Off
Tls.verify Off
# Only for logs
[OUTPUT]
Name opentelemetry
Alias opentelemetry_logs
Match *
Host 127.0.0.1
Port 4000
Logs_uri /v1/otlp/v1/logs
Log_response_payload True
Tls Off
Tls.verify Off
Header X-Greptime-Log-Table-Name "<log_table_name>"
Header X-Greptime-Log-Pipeline-Name "<pipeline_name>"
Header X-Greptime-DB-Name "<dbname>"
本示例中,使用的是 OpenTelemetry OTLP/HTTP API 接口。如需更多信息,请参阅 OpenTelemetry 文档。
Prometheus Remote Write
将 GreptimeDB 配置为远程写入目标:
[OUTPUT]
Name prometheus_remote_write
Match internal_metrics
Host 127.0.0.1
Port 4000
Uri /v1/prometheus/write?db=<dbname>
Tls Off
http_user <username>
http_passwd <password>
Uri: 发送指标的端点。http_user和http_passwd: GreptimeDB 的 认证凭据。
在 Uri 参数中:
db是你要写入指标的数据库名称。
有关从 Prometheus 到 GreptimeDB 的数据模型转换的详细信息,请参阅 Prometheus Remote Write 指南中的数据模型部分。