LoongCollector

1758
下载
LoongCollector 源自阿里云可观测性团队所开源的 iLogtail 项目,在继承了 iLogtail 强大的日志采集与处理能力的基础上,进行了全面的功能升级与扩展。从原来单一日志场景,逐步扩展为可观测数据采集、本地计算、服务发现的统一体。 LoongCollector 是一款集卓越性能、超强稳定性和灵活可编程性于一身的数据采集器,专为构建下一代可观测 Pipeline 设计。愿景是:打造业界领先的“统一可观测 Agent(Unified Observability Agent)”与“端到端可观

HTTP


简介

flusher_http flusher插件可以实现将采集到的数据,经过处理后,通过http格式发送到指定的地址。

版本

Alpha

配置参数

参数类型是否必选说明
TypeString插件类型,固定为flusher_http
RemoteURLString要发送到的URL地址,示例:http://localhost:8086/write
HeadersMap<String,String>发送时附加的http请求header,如可添加 Authorization、Content-Type等信息,支持动态变量写法,如{"x-db":"%{tag.db}"}
v2版本支持从Group的Metadata或者Group.Tags中获取动态变量,如{"x-db":"%{metadata.db}"}或者{"x-db":"%{tag.db}"}
QueryMap<String,String>发送时附加到url上的query参数,支持动态变量写法,如{"db":"%{tag.db}"}
v2版本支持从Group的Metadata或者Group.Tags中获取动态变量,如{"db":"%{metadata.db}"}或者{"db":"%{tag.db}"}
TimeoutString请求的超时时间,默认 60s
Retry.EnableBoolean是否开启失败重试,默认为 true
Retry.MaxRetryTimesInt最大重试次数,默认为 3
Retry.InitialDelayString首次重试时间间隔,默认为 1s,重试间隔以会2的倍数递增
Retry.MaxDelayString最大重试时间间隔,默认为 30s
EncoderStructilogtail数据编码协议配置,优先级高于Convert
Encoder.TypeStringencoder 插件的类型
Encoder.OptionsMap<String,Struct>encoder 插件的配置
ConvertStructilogtail数据转换协议配置
Convert.ProtocolStringilogtail数据转换协议,可选值:custom_single,influxdb, jsonline。默认值:custom_single
v2版本可选值:raw
Convert.EncodingStringilogtail flusher数据转换编码,可选值:json, custom,默认值:json
Convert.SeparatorStringilogtail数据转换时,PipelineGroupEvents中多个Events之间拼接使用的分隔符。如\n。若不设置,则默认不拼接Events,即每个Event作为独立请求向后发送。 默认值为空。
当前仅在Convert.Protocol: raw有效。
Convert.IgnoreUnExpectedDataBooleanilogtail数据转换时,遇到非预期的数据的行为,true 跳过,false 报错。默认值 true
Convert.TagFieldsRenameMap<String,String>对日志中tags中的json字段重命名
Convert.ProtocolFieldsRenameMap<String,String>ilogtail日志协议字段重命名,可当前可重命名的字段:contents,tagstime
ConcurrencyInt向url发起请求的并发数,默认为1
MaxConnsPerHostInt每个host上的最大HTTP连接数(包含了拨号阶段的、活跃的、空闲的),默认0,表示不限制
当其值大于http.DefaultTransport.(*http.Transport).MaxConnsPerHost时(当前是0),会采用该值
MaxIdleConnsPerHostInt每个host上的最大空闲的HTTP连接数,默认0,表示不限制
当其值大于http.DefaultTransport.(*http.Transport).MaxIdleConnsPerHost时(当前是0),会采用该值
IdleConnTimeoutStringHTTP连接在关闭前保持闲置状态的最长时间,默认90s
当其值大于http.DefaultTransport.(*http.Transport).IdleConnTimeout时(当前是90s),会采用该值
WriteBufferSizeInt写缓冲区的大小,不填不会给http.DefaultTransport.(*http.Transport).WriteBufferSize赋值,此时采用默认的4KB
当其值大于0时,会采用该值
QueueCapacityInt内部channel的缓存大小,默认为1024
AuthenticatorStruct鉴权扩展插件配置
Authenticator.TypeString鉴权扩展插件类型
Authenticator.OptionsMap<String,Struct>鉴权扩展插件配置内容
AsyncInterceptBoolean异步过滤数据,默认为否
DropEventWhenQueueFullBoolean当队列满时是否丢弃数据,否则需要等待,默认为不丢弃
Compressionstring压缩策略,目前支持gzip和snappy,默认不开启

样例

采集/home/test-log/路径下的所有文件名匹配*.log规则的文件,并将采集结果以 custom_single 协议、json格式提交到 http://localhost:8086/write
且提交时,附加 header x-filepath,其值使用log中的 Tag:path 的值

enable: true
inputs:
- Type: input_file
FilePaths:
- /home/test-log/*.log
flushers:
- Type: flusher_http
RemoteURL: "http://localhost:8086/write"
Headers:
x-filepath: "%{tag.__path__}"
Convert:
Protocol: custom_single
Encoding: json

采集Docker日志,并将采集结果以jsonline协议发送到http://localhost:9428/insert/jsonline

enable: true
inputs:
- Type: service_docker_stdout
Stderr: true
Stdout: true
processors:
- Type: processor_json
SourceKey: content
KeepSource: true
ExpandDepth: 1
ExpandConnector: ""
KeepSourceIfParseError: true
flushers:
- Type: flusher_http
RemoteURL: http://localhsot:9428/insert/jsonline
QueueCapacity: 64
Convert:
Protocol: jsonline
Encoding: json

需要注意的是,由于使用jsonline协议(会将日志的content和tag打平),所以仅支持使用json格式进行提交。
由于jsonline默认会批量提交日志,所以建议调低QueueCapacity,避免在日志量较大的情况下,发生内存占用过多或OOM的问题。

采集Prometheus指标,并将指标以Prometheus协议发送到PROMETHEUS_REMOTEWRITE_ADDRESS
这里用到了ext_default_encoder插件,该插件可以配置使用Prometheus Encoder,从而支持将采集到的数据转换为Prometheus协议。

enable: true
global:
StructureType: v2
inputs:
- Type: service_prometheus
ConfigFilePath: '/etc/prometheus/prometheus.yml'
flushers:
- Type: flusher_http
RemoteURL: 'http://PROMETHEUS_REMOTEWRITE_ADDRESS/api/v1/write'
Concurrency: 10
QueueCapacity: 4096
DropEventWhenQueueFull: true
Encoder:
Type: ext_default_encoder
Format: 'prometheus'
SeriesLimit: 1024
Authenticator:
Type: ext_basicauth
Compression: 'snappy'
extensions:
- Type: ext_basicauth
Username: 'YOUR_USERNAME'
Password: 'YOUR_PASSWORD'

observability.cn Authors 2024 | Documentation Distributed under CC-BY-4.0
Copyright © 2017-2024, Alibaba. All rights reserved. Alibaba has registered trademarks and uses trademarks.
浙ICP备2021005855号-32