Kubernetes从0到1-第四篇 使用EFK收集Kubernetes日志

2024-05-31 07:38

本文主要是介绍Kubernetes从0到1-第四篇 使用EFK收集Kubernetes日志,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

    • Elasticsearch 插件
    • #1. 创建命名空间
    • #2. 部署Elasticsearch
    • #3. 部署fluentd
    • #4. 部署kibana
    • #5. 添加索引

Elasticsearch 插件

此附加组件由 Elasticsearch、Fluentd 和 Kibana 组合而成。 Elasticsearch 是一个搜索引擎,负责存储我们的日志并允许查询它们。 Fluentd 将日志消息从 Kubernetes 发送到 Elasticsearch,而 Kibana 是一个图形界面,用于查看和查询存储在 Elasticsearch 中的日志。

#1. 创建命名空间

创建logging-ns.yaml

kind: Namespace
apiVersion: v1
metadata:name: logginglabels:k8s-app: loggingkubernetes.io/cluster-service: "true"addonmanager.kubernetes.io/mode: Reconcile

应用yaml文件

$ kubectl apply -f logging-ns.yaml

#2. 部署Elasticsearch

添加chart仓库

$ helm repo add elastic https://helm.elastic.co
$ helm repo update
$ helm pull elastic/elasticsearch --version 7.5.2
$ tar -xvf elasticsearch-7.5.2.tgz && cd elasticsearch

安装

$ helm install elasticsearch . -n logging -f ./values.yaml

查看pv、pvc

$ kubectl get pv
NAME                                       CAPACITY   ACCESS MODES   RECLAIM POLICY   STATUS   CLAIM                                                 STORAGECLAS                          S          REASON   AGE
pvc-23431c9b-d017-490b-946d-4fb4a3a14a2f   10Gi       RWO            Delete           Bound    logging/elasticsearch-master-elasticsearch-master-0   managed-nfs                          -storage            99s
$ kubectl get pvc -n logging
NAME                                          STATUS   VOLUME                                     CAPACITY   ACCESS MODES   STORAGECLASS          AGE
elasticsearch-master-elasticsearch-master-0   Bound    pvc-23431c9b-d017-490b-946d-4fb4a3a14a2f   10Gi       RWO            managed-nfs-storage   106s

查看pod状态

$ kubectl get pods -n logging
NAME                     READY   STATUS    RESTARTS   AGE
elasticsearch-master-0   1/1     Running   0          2m43s

查看service

$ kubectl get svc -n logging
NAME                            TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)             AGE
elasticsearch-master            ClusterIP   10.1.185.112   <none>        9200/TCP,9300/TCP   9m44s
elasticsearch-master-headless   ClusterIP   None           <none>        9200/TCP,9300/TCP   9m44s

#3. 部署fluentd

下载chart

$ helm pull incubator/fluentd-elasticsearch --version 0.7.1
$ tar -xvf fluentd-elasticsearch-0.7.1.tgz && cd fluentd-elasticsearch

修改values.yaml

image:repository: quay.io/fluentd_elasticsearch/fluentdtag: v3.1.0pullPolicy: IfNotPresent
elasticsearch:host: 'elasticsearch-master-0'port: 9200

安装

$ helm install fluentd . -n logging -f ./values.yaml

查看pod状态

$ kubectl get pods -n logging
NAME                                  READY   STATUS    RESTARTS   AGE
elasticsearch-master-0                1/1     Running   0          62m
fluentd-fluentd-elasticsearch-dgjc7   1/1     Running   0          111s
fluentd-fluentd-elasticsearch-hhgpr   1/1     Running   0          110s

查看configmap

$ kubectl get configmaps -n logging
NAME                            DATA   AGE
fluentd-fluentd-elasticsearch   6      34m

#4. 部署kibana

下载chart

$ helm pull elastic/kibana --version 7.5.2
$ tar -xvf kibana-7.5.2.tgz && cd kibana

修改values.yaml

elasticsearchURL: "http://elasticsearch-master:9200"
elasticsearchHosts: "http://elasticsearch-master:9200"kibanaConfig: kibana.yml: |server.name: kibanaserver.host: "0.0.0.0"elasticsearch.hosts: [ "http://elasticsearch-master:9200" ]service:type: LoadBalancerloadBalancerSourceRanges: - 192.168.238.0/24
ingress:enabled: truehosts:- kibana.demo.com

安装

$ helm install kibana . -n logging -f ./values.yaml

查看pod状态

$ kubectl get pod -n logging
NAME                                  READY   STATUS    RESTARTS   AGE
elasticsearch-master-0                1/1     Running   1          4d18h
fluentd-fluentd-elasticsearch-dgjc7   1/1     Running   17         4d17h
fluentd-fluentd-elasticsearch-hhgpr   1/1     Running   17         4d17h
kibana-kibana-86866c888-8z2c5         1/1     Running   0          10m

查看ingress

$ kubectl get ingress -n logging
NAME            CLASS    HOSTS             ADDRESS           PORTS   AGE
kibana-kibana   <none>   kibana.demo.com   192.168.238.156   80      4d16h

访问kibana,设置本地host解析,kibana.demo.com
在这里插入图片描述

#5. 添加索引

Fluentd 配置文件中采集的日志使用的是 logstash 格式,只需要输入logstash-*即可匹配到 Elasticsearch 集群中的所有日志数据。
其他对索引个性化需求的,可以自行配置。

在这里插入图片描述

在这里插入图片描述

参考文档:
[1]: https://github.com/kubernetes/kubernetes/tree/master/cluster/addons/fluentd-elasticsearch

这篇关于Kubernetes从0到1-第四篇 使用EFK收集Kubernetes日志的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1017578

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆