Promtail 数据接入¶
启动一个 HTTP 端点监听并接收 Promtail 日志数据,上报到观测云。
配置¶
已测试的版本:
- 2.8.2
- 2.0.0
- 1.5.0
- 1.0.0
- 0.1.0
采集器配置¶
进入 DataKit 安装目录下的 conf.d/log
目录,复制 promtail.conf.sample
并命名为 promtail.conf
。示例如下:
[inputs.promtail]
## When processing requests with the legacy version interface,
## setting it to true corresponds to the Loki API endpoint /api/prom/push.
#
legacy = false
[inputs.promtail.tags]
# some_tag = "some_value"
# more_tag = "some_other_value"
配置好后,重启 DataKit 即可。
目前可以通过 ConfigMap 方式注入采集器配置来开启采集器。
API 版本¶
对于 v0.3.0
及之前的版本需要配置 legacy = true
,即使用 POST /api/prom/push
,可以用 Legacy 版本 API 处理接收 Promtail 的日志数据。
之后的版本使用默认配置,即 legacy = false
,即使用 POST /loki/api/v1/push
。
自定义标签¶
通过配置 [inputs.promtail.tags]
,可以在日志数据中添加自定义标签,示例如下:
配置好后,重启 DataKit 即可。
支持参数¶
Promtail 采集器支持在 HTTP URL 中添加参数。参数列表如下:
source
:标识数据来源。例如nginx
或者redis
(/v1/write/promtail?source=nginx
),默认将source
设为default
;pipeline
:指定数据需要使用的 pipeline 名称,例如nginx.p
(/v1/write/promtail?pipeline=nginx.p
);tags
:添加自定义 tag,以英文逗号,
分割,例如key1=value1
和key2=value2
(/v1/write/promtail?tags=key1=value1,key2=value2
)。
示例¶
Promtail 的数据原本发送给 Loki,即 /loki/api/v1/push
。将 Promtail 配置中的 url
修改为指向 Datakit,开启 Datakit 的 Promtail 采集器后,Promtail 会将其数据发送给 Datakit 的 Promtail 采集器。
Promtail 的配置示例如下:
server:
http_listen_port: 9080
grpc_listen_port: 0
positions:
filename: /tmp/positions.yaml
clients:
- url: http://localhost:9529/v1/write/promtail # 发送到 promtail 采集器监听的端点
scrape_configs:
- job_name: system
static_configs:
- targets:
- localhost
labels:
job: varlogs
__path__: /var/log/*log
日志¶
以 Promtail 通过过来的日志为准。