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 检查配置语法。

相关推荐
Full Stack Developme1 小时前
JVM 与 Linux 交互的核心原理
linux·运维·jvm
Java识堂1 小时前
多级负载均衡架构
运维·架构·负载均衡
MXsoft6181 小时前
## 自动化巡检:从手工两小时到系统五分钟的落地实践
运维·自动化
ZLG_zhiyuan1 小时前
直击华南工博会|ZLG致远电子:EtherCAT与自动化总线应用方案动态实景呈现
运维·自动化
HackTwoHub2 小时前
最新Nessus2026.6.8版本主机漏洞扫描/探测工具Windows/Linux
linux·运维·服务器·安全·web安全·网络安全·安全架构
Nayxxu2 小时前
Gemini + RAG 企业知识库教程:从文档切片到答案生成
运维·人工智能
三雷科技4 小时前
Claude Code 命令行完全指南:从高效交互到自动化工作流
运维·自动化·交互
正经教主4 小时前
【docker基础】第五课:Docker网络详解
运维·docker·容器
小黑蛋学java5 小时前
Nginx 接口耗时 Prometheus + Grafana 监控实施方案
运维·nginx·负载均衡·grafana·prometheus
鹤鸣的日常6 小时前
前端运行时动态环境变量方案
前端·react.js·docker·前端框架·vue·gitlab