LoongCollector

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

ElasticSearch



简介

flusher_elasticsearch flusher插件可以实现将采集到的数据,经过处理后,发送到 ElasticSearch,需要 ElasticSearch 版本至少为 8

版本

Alpha

配置参数

参数类型是否必选说明
TypeString插件类型,固定为flusher_elasticsearch
AddressesString数组ElasticSearch 地址
ConvertStructilogtail数据转换协议配置
Convert.ProtocolStringilogtail数据转换协议,elasticsearch flusher 可选值:custom_single,custom_single_flatten,otlp_log_v1。默认值:custom_single
Convert.EncodingStringilogtail flusher数据转换编码,可选值:jsonnoneprotobuf,默认值:json
Convert.TagFieldsRenameMap对日志中tags中的json字段重命名
Convert.ProtocolFieldsRenameMapilogtail日志协议字段重命名,可当前可重命名的字段:contents,tagstime
IndexString插入数据目标索引
AuthenticationStructElasticSearch 连接访问认证配置
Authentication.PlainText.UsernameStringElasticSearch 用户名
Authentication.PlainText.PasswordStringElasticSearch 密码
Authentication.TLS.EnabledBoolean是否启用 TLS 安全连接,
Authentication.TLS.CAFileStringTLS CA 根证书文件路径
Authentication.TLS.CertFileStringTLS 连接证书文件路径
Authentication.TLS.KeyFileStringTLS 连接私钥文件路径
Authentication.TLS.MinVersionStringTLS 支持协议最小版本,可选配置:1.0, 1.1, 1.2, 1.3,默认:1.2
Authentication.TLS.MaxVersionStringTLS 支持协议最大版本,可选配置:1.0, 1.1, 1.2, 1.3,默认采用:crypto/tls支持的版本,当前1.3
HTTPConfig.MaxIdleConnsPerHostInt每个host的连接池最大空闲连接数
HTTPConfig.ResponseHeaderTimeoutString读取头部的时间限制,可选配置NanosecondMicrosecondMillisecondSecondMinuteHour

Elasticsearch动态索引格式化

开发插件往Elasticsearch写入数据时。用户往往存在一些动态索引的需求,动态索引和kafka的动态topic稍微有些区别。 动态索引常见的使用场景如下:

  • 按照业务字段标识动态创建索引,和Kafka的动态topic一样。
  • 基于时间的索引创建,按天、按周、按月等。在ELK社区例常见的案例:%{+yyyy.MM.dd}基于天创建,%{+yyyy.ww}基于周创建

结合两种需求,动态索引的创建规则如下:

  • %{content.fieldname}content代表从contents中取指定字段值
  • %{tag.fieldname},tag表示从tags中取指定字段值,例如:%{tag.k8s.namespace.name}
  • ${env_name}, 使用$符直接从环境变量中获取,从1.5.0版本支持
  • %{+yyyy.MM.dd},按天创建,注意表达式前面时间格式前面的+符号不能缺少。
  • %{+yyyy.ww},按周创建,还有其他时间格式就不一一举例。由于golang时间格式看起来不是非常人性化, 表达式使用上直接参考ELK社区的格式。

格式化动态索引的函数如下:

func FormatIndex(targetValues map[string]string, indexPattern string, indexTimestamp uint32) (*string, error)
  • targetValues使用Convert协议转换处理后需要替换的键值对。可参考flusher_kafka_v2中的对ToByteStreamWithSelectedFields的使用。
  • indexPattern动态索引表达式。
  • indexTimestampLog这个pb中的time字段类型一致方便可以使用日志中的时间来格式化动态索引。

样例

常规索引

采集/home/test-log/路径下的所有文件名匹配*.log规则的文件,并将采集结果发送到 ElasticSearch。

enable: true
inputs:
- Type: input_file
FilePaths:
- /home/test-log/*.log
flushers:
- Type: flusher_elasticsearch
Addresses:
- http://192.XX.XX.1:9092
- http://192.XX.XX.2:9092
Index: default
Authentication:
PlainText:
Username: user
Password: 123456
HTTPConfig:
MaxIdleConnsPerHost: 10
ResponseHeaderTimeout: Second

动态索引

采集结果支持写入ElasticSearch动态索引,例如,数据写入到一个名字包含当前日期的索引,可以这样写(只提供flushers)。

flushers:
- Type: flusher_elasticsearch
Addresses:
- http://192.XX.XX.1:9092
- http://192.XX.XX.2:9092
Index: log_%{+yyyyMMdd}
Authentication:
PlainText:
Username: user
Password: 123456

数据平铺写入

ilogtail 1.8.0新增数据平铺协议custom_single_flattencontentstagstime三个convert层的协议字段中数据做一级打平。 当前convert协议在单条数据处理仅支持json编码,因此custom_single_flatten需要配合json编码一起使用。

enable: true
inputs:
- Type: input_file
FilePaths:
- /home/test-log/*.log
flushers:
- Type: flusher_elasticsearch
Addresses:
- http://192.XX.XX.1:9092
- http://192.XX.XX.2:9092
Convert:
Protocol: custom_single_flatten
Encoding: json
Index: default

非平铺前写入ElasticSearch的数据格式

{
"contents": {
"class": "org.springframework.web.servlet.DispatcherServlet@initServletBean:547",
"application": "springboot-docker",
"level": "ERROR",
"message": "Completed initialization in 9 ms",
"thread": "http-nio-8080-exec-10",
"@time": "2022-07-20 16:55:05.415"
},
"tags": {
"k8s.namespace.name":"java_app",
"host.ip": "192.168.6.128",
"host.name": "master",
"log.file.path": "/data/test.log"
},
"time": 1664435098
}

使用平铺协议后custom_single_flattenjson全部被一级平铺。

{
"class": "org.springframework.web.servlet.DispatcherServlet@initServletBean:547",
"application": "springboot-docker",
"level": "ERROR",
"message": "Completed initialization in 9 ms",
"thread": "http-nio-8080-exec-10",
"@time": "2022-07-20 16:55:05.415",
"k8s.namespace.name":"java_app",
"host.ip": "192.168.6.128",
"host.name": "master",
"log.file.path": "/data/test.log",
"time": 1664435098
}

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