LoongCollector

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

目录结构说明



LoongCollector 的 目录结构说明

产品更名说明

作为 2024 年产品规划的重要组成部分,iLogtail 产品将正式更名为 LoongCollector。此次更新主要包含以下变更:

  • 程序二进制文件由 iLogtail 更名为 LoongCollector

  • 全面优化目录结构和配置文件布局,提供更清晰的组织方式

新版目录结构

LoongCollector 采用模块化的分层目录设计,以下展示了安装在 /opt/loongcollector 下的标准目录结构:

库文件:

  • /opt/loongcollector/libPluginAdapter.so

  • /opt/loongcollector/libPluginBase.so

自带证书:/opt/loongcollector/ca-bundle.crt

配置文件目录:/opt/loongcollector/conf

日志配置文件:

  • /opt/loongcollector/conf/apsara_log_conf.json

  • /opt/loongcollector/conf/plugin_logger.xml

标识配置文件:

  • /opt/loongcollector/conf/user_defined_id

采集配置文件:/opt/loongcollector/conf/continuous_pipeline_config

进程级文件:/opt/loongcollector/conf/instance_config

数据目录:/opt/loongcollector/data

检查点:

  • /opt/loongcollector/data/go_plugin_checkpoint

  • /opt/loongcollector/data/exactly_once_checkpoint

  • /opt/loongcollector/data/file_check_point

容器路径映射:/opt/loongcollector/data/docker_path_config.json

未发送数据:/opt/loongcollector/data/send_buffer_file_xxxxxxxxxxxx

Crash临时文件:/opt/loongcollector/data/backtrace.dat

日志目录:/opt/loongcollector/log

主要日志:/opt/loongcollector/log/loongcollector.log

Go插件日志:/opt/loongcollector/log/go_plugin.log

日志库初始化日志:/opt/loongcollector/log/logger_initialization.log

Profile日志:/opt/loongcollector/log/snapshot

run目录:/opt/loongcollector/run

Pid文件:/opt/loongcollector/run/loongcollector.pid

inotify日志:/opt/loongcollector/run/inotify_watcher_dirs

进程信息日志:/opt/loongcollector/run/app_info.json

/
└── /opt/loongcollector/
├── loongcollector # 主程序
├── libPluginAdapter.so
├── libPluginBase.so
├── ca-bundle.crt
├── plugins/ # 插件目录
│ └── custom plugins # 自定义插件
├── dump # 仅由 service_http_server 输入插件使用
├── thirdparty/ # 第三方依赖
│ ├── jvm
│ └── telegraf
├── conf/ # 配置目录
│ ├── scripts
│ ├── apsara_log_conf.json
│ ├── plugin_logger.xml
│ ├── user_defined_id
│ ├── authorization.json
│ ├── continuous_pipeline_config/
│ │ ├── local/
│ │ │ └── collect_stdout.json
│ │ └── remote/
│ │ └── collect_file.json
│ └── instance_config/
│ ├── local/
│ │ ├── loongcollector_config.json(loongcollector配置)
│ │ └── ebpf.json
│ └── remote/
│ ├── region.json
│ └── resource.json
├── data/ # 数据目录
│ ├── file_check_point # 文件采集的checkpoint
│ ├── exactly_once_checkpoint/
│ ├── go_plugin_checkpoint/ # go插件采集的checkpoint
│ ├── docker_path_config.json
│ ├── send_buffer_file_xxxxxxxxxxxx
│ └── backtrace.dat
├── log/ # 日志目录
│ ├── loongcollector.log
│ ├── loongcollector.log.1
│ ├── go_plugin.log
│ ├── go_plugin.log.1
│ ├── logger_initialization.log
│ └── snapshot/
└── run/
├── loongcollector.pid
├── inotify_watcher_dirs
└── app_info.json

目录自定义配置

支持的自定义目录参数

LoongCollector 提供以下参数用于自定义各类目录位置:

  • 配置目录: gflag为conf_dir、环境变量为LOONG_CONF_DIR

  • 日志目录: gflag为logs_dir、环境变量为LOONG_LOGS_DIR

  • 数据目录: gflag为data_dir、环境变量为LOONG_DATA_DIR

  • 运行时目录: gflag为run_dir、环境变量为LOONG_RUN_DIR

  • 第三方依赖目录: gflag为third_party_dir、环境变量为LOONG_THIRD_PARTY_DIR

配置方式

  1. 命令行参数:

    Terminal window
    ./loongcollector --conf_dir=/custom/path/conf
  2. 环境变量:

    Terminal window
    export LOONG_CONF_DIR=/custom/path/conf
    ./loongcollector

命名变更对照表

为确保命名一致性,我们对以下文件和目录进行了规范化命名:

文件/目录作用原命名新命名
agent可观测文件logtail_monitor_infoloongcollector_monitor_info
go插件采集的checkpointcheckpointgo_plugin_checkpoint
go插件运行日志logtail_plugin.LOGgo_plugin.LOG
采集配置目录名configcontinuous_pipeline_config
exactly_once的checkpointcheckpoint_v2exactly_once_checkpoint
agent的发送缓冲buffer文件logtail_buffer_file_xxxsend_buffer_file_xxx
agent可观测文件ilogtail_status.LOGloongcollector_status.LOG
agent运行日志ilogtail.LOGloongcollector.LOG

配置兼容性说明

为简化配置体系,以下原 Logtail 配置项将不再默认支持:

  • sls_observer_ebpf_host_path

  • logtail_snapshot_dir

  • inotify_watcher_dirs_dump_filename

  • local_event_data_file_name

  • crash_stack_file_name

  • check_point_filename

  • adhoc_check_point_file_dir

  • app_info_file

  • ilogtail_config

  • ilogtail_config_env_name

  • logtail_sys_conf_dir

  • ALIYUN_LOGTAIL_SYS_CONF_DIR

  • ilogtail_docker_file_path_config

升级建议

  1. 兼容模式: 如需保持与 Logtail 的兼容性,请参考 Logtail 兼容模式使用指南

  2. 新版迁移: 如果选择使用新版目录结构:

    • 建议先备份原有配置和数据

    • 按新版目录结构迁移文件

    • 更新相关配置引用

    • 验证服务正常运行

为确保平稳迁移,我们建议您:

  1. 先在测试环境进行充分验证

  2. 选择业务低峰期进行升级

  3. 做好配置和数据的备份

  4. 逐步迁移,避免一次性升级所有实例

  5. 密切监控日志采集状态

注意: 迁移过程中请确保数据完整性,建议先在测试环境中进行测试,并非高峰期进行升级操作。


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