syslog-ng 开源项目教程
1. 项目介绍
syslog-ng 是一个增强型的日志守护进程,支持广泛的输入和输出方法,包括系统日志(syslog)、非结构化文本、消息队列、SQL 和 NoSQL 数据库等。它能够接收和发送 RFC3164 和 RFC5424 风格的系统日志消息,以及 JSON 格式的消息。syslog-ng 还提供了强大的日志分类、结构化、归一化和处理功能,能够将日志转发到各种大数据工具,如 Elasticsearch、Apache Kafka 和 Apache Hadoop。
2. 项目快速启动
2.1 安装
首先,确保你已经安装了必要的依赖。然后,你可以通过以下命令从源代码编译和安装 syslog-ng:
$ ./configure && make && make install
如果你没有 configure 脚本(例如从 Git 克隆项目时),可以运行以下命令生成它:
$ ./autogen.sh
2.2 配置
以下是一个简单的配置示例,它从 /dev/log 接收系统日志,并将所有日志写入一个文件:
@version: 4.8
@include "scl.conf"
log {
source { system(); };
destination { file("/var/log/syslog"); };
};
如果你想从网络接收日志(默认使用 TCP/514 端口),可以使用以下配置:
@version: 4.8
@include "scl.conf"
log {
source { system(); network(); };
destination { file("/var/log/syslog"); };
};
2.3 启动
配置完成后,启动 syslog-ng 服务:
$ syslog-ng -f /path/to/your/config/file
3. 应用案例和最佳实践
3.1 日志分类与结构化
syslog-ng 提供了多种内置解析器(如 csv-parser()、db-parser()、kv-parser() 等),可以帮助你分类和结构化日志。例如,以下配置使用 JSON 格式接收结构化日志,并将其输出为键值对格式:
@version: 4.8
@include "scl.conf"
log {
source { system(); };
destination { file("/var/log/app.log" template("$(format-welf --subkeys cim)\n")); };
};
你可以使用 logger 命令提交结构化日志:
$ logger '@cim: ["name1":"value1", "name2":"value2"]'
3.2 日志转发
syslog-ng 可以将日志转发到各种目标,如文件、消息队列(如 AMQP)或数据库(如 PostgreSQL 或 MongoDB)。以下是一个将日志转发到 Elasticsearch 的示例配置:
@version: 4.8
@include "scl.conf"
log {
source { system(); };
destination { elasticsearch(
index("syslog-ng")
type("syslog")
cluster("elasticsearch")
client-mode("http")
time-zone("UTC")
); };
};
4. 典型生态项目
4.1 Elasticsearch
Elasticsearch 是一个分布式搜索和分析引擎,常用于日志和时间序列数据的存储和分析。syslog-ng 可以与 Elasticsearch 集成,将日志数据直接发送到 Elasticsearch 进行存储和分析。
4.2 Apache Kafka
Apache Kafka 是一个分布式流处理平台,常用于构建实时数据管道和流应用。syslog-ng 可以将日志数据发送到 Kafka,以便进一步处理和分析。
4.3 MongoDB
MongoDB 是一个面向文档的 NoSQL 数据库,适用于存储和查询结构化和非结构化数据。syslog-ng 可以将日志数据存储到 MongoDB 中,以便进行高效的查询和分析。
通过这些生态项目的集成,syslog-ng 能够构建强大的日志处理和分析系统,满足各种复杂的日志管理需求。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0153- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112