Fluent Bit
Fluent Bit 是一个快速且轻量级的遥测代理,用于 Linux、macOS、Windows 和 BSD 系列操作系统的日志、指标和跟踪。Fluent Bit 专注于性能,允许从不同来源收集和处理遥测数据而不增加复杂性。
您可以将 GreptimeDB 集成为 Fluent Bit 的 OUTPUT。本文档介绍如何配置 Fluent Bit 以将日志、指标和跟踪发送到 GreptimeDB。
Http
使用 Fluent Bit 的 HTTP 输出插件,您可以将日志发送到 GreptimeDB。Http 接口目前支持日志的写入。
[OUTPUT]
    Name             http
    Match            *
    Host             greptimedb
    Port             4000
    Uri              /v1/events/logs?db=public&table=your_table&pipeline_name=pipeline_if_any
    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是您要用于处理日志的管道名称。
本示例中,使用的是 Logs Http API 接口。如需更多信息,请参阅 写入日志 文档。
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 指南中的数据模型部分。