EFK(Elasticsearch + Fluentd + Kibana) 日志收集系统

一、EFK 部署步骤

  1. 创建 NFS 存储访问

◦ 启动 Master 节点的 NFS 服务,创建数据目录 /data/v1。

◦ 通过 serviceaccount.yaml、rbac.yaml、deployment.yaml、class.yaml 等资源文件配置存储访问权限和类。

  1. 构建 Elasticsearch 集群

◦ 使用 kube-logging.yaml 创建命名空间及相关资源。

◦ 通过 elasticsearch-statefulset.yaml 部署有状态的 ES 集群。

◦ 通过 elasticsearch_svc.yaml 暴露服务。

◦ 可用 kubectl port-forward 转发端口并通过 curl 测试集群健康状态。

  1. 部署 Kibana

◦ 定义 Deployment 和 Service(NodePort 类型)。

◦ 使用环境变量 ELASTICSEARCH_URL 指向 ES 服务。

◦ 支持通过 ConfigMap 挂载 kibana.yml 实现汉化(配置 i18n.locale: "zh-CN")。

◦ 创建资源后可通过 kubectl get pods,svc -n kube-logging 验证。

  1. 安装 Fluentd 组件

◦ 通过 fluentd.yaml 部署 Fluentd,作为日志收集器,负责采集容器日志并发送到 ES。

二、Fluentd 配置详解

Fluentd 配置采用"数据管道"模型,核心三要素:输入(source)→ 过滤(filter)→ 输出(match)。

• 标签(Tag):日志的路由标识,支持通配符 * 和 **。

• 指令类型:

◦ <source>:定义输入源(如 tail 监控文件、forward 接收 TCP 日志)。

◦ <filter>:对匹配 tag 的事件进行解析、修改、过滤。

◦ <match>:将匹配 tag 的事件输出到目标(如 ES、S3、stdout)。

◦ 其他:<label>、<parse>、<format>、<buffer> 等。

• 插件(@type):tail, forward, parser, record_modifier, elasticsearch, s3, stdout 等。

典型配置示例:

• 输入 Nginx 访问日志(tail + nginx 解析器)。

• 过滤:用 grok 进一步解析 message 字段,用 record_modifier 添加/删除字段。

• 输出:匹配不同 tag 分别发往 ES(按索引区分)或控制台打印。

• 缓冲配置:使用 <buffer> 提高可靠性(file 类型,设置刷新间隔和 chunk 大小)。

最佳实践:

• 先用 @type stdout 调试。

• 规划标签命名策略。

• 务必配置 buffer(尤其是网络输出)。

• 使用环境变量保护敏感信息。

• 用 fluentd --dry-run -c 检查配置语法。

相关推荐
终端行者7 小时前
Jenkins Pipeline 企业级用法 参数化构建+Ansible发布---上
docker·ansible·jenkins·cicd
ccice018 小时前
硬核实战:调用Gemini多模态管道,直击办公中的图表解析、发票识别与自动化脚本生成(国内镜像免费方案)
运维·自动化
爱喝水的鱼丶8 小时前
SAP-ABAP:数据类型与数据对象(8篇) 第七篇:进阶优化篇——基于类型与对象特征的性能优化技巧
运维·数据库·学习·性能优化·sap·abap·开发交流
DFT计算杂谈8 小时前
VASP新手入门: IVDW 色散修正参数
linux·运维·服务器·python·算法
qq_366032788 小时前
Claude API中转怎么选?简易api下的国内接入与兼容 OpenAI 接口实践
大数据·运维·人工智能
Donk_678 小时前
HAProxy实验搭建
运维·负载均衡
青梅橘子皮8 小时前
Linux---开发工具(2)(makefile、进度条、git、gdb)
linux·运维·服务器
亚空间仓鼠8 小时前
Docker容器化高可用架构部署方案(十三)
docker·容器·架构
剑神一笑9 小时前
Linux less 命令深度解析:从源码看分页器的设计智慧
linux·运维·less