在K8S中,如何使用 EFK 实现日志的统一管理?

本文涉及的产品
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
日志服务 SLS,月写入数据量 50GB 1个月
简介: 在K8S中,如何使用 EFK 实现日志的统一管理?

在Kubernetes(K8s)中,EFK(Elasticsearch, Fluentd, Kibana)是一种常见的日志统一管理方案。EFK堆栈允许你收集、存储、搜索、分析和可视化容器化应用程序的日志。下面是如何在Kubernetes中使用EFK实现日志统一管理的详细步骤:

1. 部署Elasticsearch

Elasticsearch是一个分布式、RESTful风格的搜索和分析引擎,能够解决越来越多用例的查询语言,它通常用于日志和事件数据分析。

首先,你需要在Kubernetes集群中部署Elasticsearch。这可以通过使用官方的Elasticsearch Helm chart或自定义YAML配置文件来完成。确保你的Elasticsearch集群有足够的资源,并且已经正确配置以满足你的日志存储和查询需求。

2. 部署Fluentd

Fluentd是一个开源的数据收集器,用于统一日志管理。在Kubernetes中,Fluentd通常作为DaemonSet运行,在每个节点上收集容器日志。

部署Fluentd涉及到创建一个DaemonSet资源对象,该对象会在每个节点上运行一个Fluentd实例。Fluentd的配置文件定义了日志的来源、过滤和处理方式,以及日志发送到Elasticsearch的方式。

下面是一个Fluentd的DaemonSet示例配置:

apiVersion: apps/v1
kind: DaemonSet
metadata:
name: fluentd-elasticsearch
namespace: kube-system
labels:
k8s-app: fluentd-logging
spec:
selector:
matchLabels:
name: fluentd-elasticsearch
template:
metadata:
labels:
name: fluentd-elasticsearch
spec:
containers:
- name: fluentd-elasticsearch
image: fluent/fluentd-kubernetes-daemonset:v1.11-debian-elasticsearch-1.0
env:
- name:  FLUENTD_ELASTICSEARCH_HOST
value: "elasticsearch-master.kube-system.svc:9200"
- name:  FLUENTD_ELASTICSEARCH_SCHEME
value: "http"
volumeMounts:
- name: varlog
mountPath: /var/log
- name: varlibdockercontainers
mountPath: /var/lib/docker/containers
readOnly: true
terminationGracePeriodSeconds: 30
volumes:
- name: varlog
hostPath:
path: /var/log
- name: varlibdockercontainers
hostPath:
path: /var/lib/docker/containers

在上面的配置中,Fluentd容器被配置为从主机的/var/log/var/lib/docker/containers路径收集日志,并将它们发送到Elasticsearch集群。

3. 部署Kibana

Kibana是一个Web应用程序,用于搜索、查看和交互存储在Elasticsearch索引中的日志数据。

部署Kibana可以通过使用官方的Kibana Helm chart或自定义YAML配置文件来完成。Kibana的配置通常很简单,主要是指定它要连接的Elasticsearch实例。

下面是一个Kibana的Deployment示例配置:

apiVersion: apps/v1
kind: Deployment
metadata:
name: kibana
namespace: kube-system
spec:
replicas: 1
selector:
matchLabels:
app: kibana
template:
metadata:
labels:
app: kibana
spec:
containers:
- name: kibana
image: docker.elastic.co/kibana/kibana:7.10.0
ports:
- containerPort: 5601
env:
- name: ELASTICSEARCH_URL
value: http://elasticsearch-master.kube-system.svc:9200
- name: ELASTICSEARCH_HOSTS
value: http://elasticsearch-master.kube-system.svc:9200

在这个配置中,Kibana容器被配置为连接到名为elasticsearch-master的Elasticsearch服务。

4. 验证和使用

一旦所有组件都部署完成,你可以通过访问Kibana的Web界面(通常是http://<Kibana-Pod-IP>:5601)来验证日志统一管理是否工作正常。在Kibana中,你可以创建索引模式、搜索日志、创建可视化图表等。

5.注意事项
  • 确保Elasticsearch、Fluentd和Kibana之间的网络连通性。
  • 根据你的日志量和存储需求,合理配置Elasticsearch集群的存储和性能。
  • 监控Elasticsearch和Fluentd的性能和资源使用情况,确保它们不会成为集群的瓶颈。
  • 定期备份Elasticsearch数据以防止数据丢失。
  • 考虑使用TLS/SSL加密Fluentd和Elasticsearch之间的通信以提高安全性。
相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
4月前
|
Kubernetes Ubuntu Windows
【Azure K8S | AKS】分享从AKS集群的Node中查看日志的方法(/var/log)
【Azure K8S | AKS】分享从AKS集群的Node中查看日志的方法(/var/log)
146 3
|
3月前
|
Kubernetes API Docker
跟着iLogtail学习容器运行时与K8s下日志采集方案
iLogtail 作为开源可观测数据采集器,对 Kubernetes 环境下日志采集有着非常好的支持,本文跟随 iLogtail 的脚步,了解容器运行时与 K8s 下日志数据采集原理。
|
4月前
|
消息中间件 Kubernetes API
在K8S中,如何收集k8s集群日志?
在K8S中,如何收集k8s集群日志?
|
3月前
|
运维 Kubernetes 监控
Loki+Promtail+Grafana监控K8s日志
综上,Loki+Promtail+Grafana 监控组合对于在 K8s 环境中优化日志管理至关重要,它不仅提供了强大且易于扩展的日志收集与汇总工具,还有可视化这些日志的能力。通过有效地使用这套工具,可以显著地提高对应用的运维监控能力和故障诊断效率。
408 0
|
4月前
|
消息中间件 Kubernetes Kafka
微服务从代码到k8s部署应有尽有系列(十一、日志收集)
微服务从代码到k8s部署应有尽有系列(十一、日志收集)
|
4月前
|
Kubernetes Shell 网络安全
【Azure K8S】记录AKS VMSS实例日志收集方式
【Azure K8S】记录AKS VMSS实例日志收集方式
|
4月前
|
存储 Prometheus Kubernetes
在K8S中,如何收集K8S日志?有哪些方案?
在K8S中,如何收集K8S日志?有哪些方案?
|
4月前
|
Kubernetes API Docker
在K8S中,如何查看kubelet组件的日志?
在K8S中,如何查看kubelet组件的日志?
|
存储 JSON Kubernetes
Kubernetes 中日志的正确输出姿势
本文我们将从实践角度出发来一步步构建K8s中的日志监控体系。构建日志系统的第一步是如何去产生这些日志,而这也往往是最繁杂最困难的一步。
1515 0
Kubernetes 中日志的正确输出姿势
|
存储 JSON Kubernetes
系列文章:Kubernetes中日志的正确输出姿势
上一期主要和大家介绍从全局维度考虑如何去构建K8s中的日志系统,本期我们从实践角度出发来一步步构建K8s中的日志监控体系。构建日志系统的第一步是如何去产生这些日志,而这也往往是最繁杂最困难的一步。
5118 0