Spring Boot 整合 ELK 全面指南:实现日志采集、分析与可视化


一、ELK简介

1.1 什么是ELK?

ELK 是三个开源工具的组合:

  1. Elasticsearch:一个分布式全文搜索和分析引擎,用于存储和查询日志数据。
  2. Logstash:一个数据处理管道工具,用于收集、解析和处理日志数据。
  3. Kibana:一个可视化工具,用于以图表和仪表盘的形式展示日志数据。

这三者相互协作,为开发者和运维人员提供了强大的日志管理能力。


1.2 ELK 的核心功能

  • 日志收集与处理:通过 Logstash 或 Filebeat 收集和清洗日志数据。
  • 全文搜索与分析:利用 Elasticsearch 的强大搜索功能快速定位问题。
  • 数据可视化:Kibana 提供丰富的图表工具,将日志数据转化为易于理解的仪表盘。

二、整合目标与架构设计

2.1 整合目标

在本文中,我们将实现以下功能:

  1. 日志采集:Spring Boot 应用生成的日志自动传输至 Logstash。
  2. 日志存储:Logstash 将日志发送到 Elasticsearch 进行存储。
  3. 日志可视化:在 Kibana 中配置仪表盘,实现日志查询和监控。

2.2 架构设计

整合的架构如下:

  1. Spring Boot:产生日志,格式为 JSON 或普通文本。
  2. Logstash:从文件或网络输入接收日志数据,清洗并转发到 Elasticsearch。
  3. Elasticsearch:存储和索引日志数据。
  4. Kibana:连接 Elasticsearch,用于查询和展示数据。

三、环境准备

3.1 安装 ELK 环境

1. 下载 ELK

从官方 Elastic 网站下载 Elasticsearch、Logstash、Kibana。

2. 安装与启动

以 Linux 为例:

# 启动 Elasticsearch
./bin/elasticsearch
# 启动 Logstash
./bin/logstash -f <logstash-config-file>
# 启动 Kibana
./bin/kibana

注意:默认端口

  • Elasticsearch: 9200
  • Kibana: 5601

3.2 Spring Boot 项目依赖

确保 Spring Boot 项目中引入以下依赖:

<dependencies><!-- Spring Boot 核心依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><!-- Spring Boot 日志支持 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-logging</artifactId></dependency><!-- ELK 日志集成工具(可选) --><dependency><groupId>net.logstash.logback</groupId><artifactId>logstash-logback-encoder</artifactId><version>7.4</version></dependency>
</dependencies>

四、实现日志采集与整合

4.1 配置 Spring Boot 日志

使用 Logback 作为日志框架,将日志输出为 JSON 格式。

修改 logback-spring.xml

创建或编辑项目中的 src/main/resources/logback-spring.xml

<configuration><appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss} - [%thread] %-5level %logger{36} - %msg%n</pattern></encoder></appender><appender name="LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender"><destination>127.0.0.1:5044</destination><encoder class="net.logstash.logback.encoder.LogstashEncoder" /></appender><root level="info"><appender-ref ref="CONSOLE" /><appender-ref ref="LOGSTASH" /></root>
</configuration>

说明LOGSTASH Appender 将日志发送到 Logstash 的 5044 端口。


4.2 配置 Logstash

创建 Logstash 配置文件 logstash.conf

input {tcp {port => 5044codec => json}
}
filter {# 自定义过滤规则
}
output {elasticsearch {hosts => ["http://localhost:9200"]index => "spring-boot-logs-%{+YYYY.MM.dd}"}stdout { codec => rubydebug }
}

启动 Logstash:

./bin/logstash -f logstash.conf

4.3 配置 Elasticsearch

启动 Elasticsearch,并确保可以通过 http://localhost:9200 访问。

验证集群状态:

curl -X GET "localhost:9200/_cluster/health?pretty"

4.4 配置 Kibana

http://localhost:5601 打开 Kibana:

  1. 进入 Management > Index Patterns
  2. 创建索引模式:spring-boot-logs-*
  3. 设置时间字段:@timestamp
  4. 保存并进入 Discover 查看日志数据。

五、日志可视化与查询

5.1 创建仪表盘

  1. 进入 Dashboard
  2. 添加图表,如:
    • 日志数量趋势图。
    • 错误日志分布图。
    • 日志级别统计图。

5.2 编写查询语句

Kibana 支持类似 SQL 的查询语句:

  • 查询所有错误日志:
    level: "ERROR"
    
  • 按时间范围查询:
    @timestamp >= "2024-01-01T00:00:00" AND @timestamp <= "2024-01-31T23:59:59"
    

六、整合过程中的问题与优化

6.1 常见问题

  1. 日志未能成功发送到 Logstash

    • 检查 Logback 配置中的 Logstash 地址是否正确。
    • 检查 Logstash 是否正常运行。
  2. Elasticsearch 索引未创建

    • 确保 Logstash 配置文件的 output 部分正确。
    • 检查 Elasticsearch 服务状态。
  3. Kibana 无法显示日志

    • 确保索引模式设置正确。
    • 检查 Kibana 与 Elasticsearch 的连接状态。

6.2 优化建议

  1. 日志异步发送:减少日志发送对应用性能的影响。
  2. 日志分级:根据不同级别的日志输出到不同的索引。
  3. 数据归档:定期清理旧日志,降低 Elasticsearch 存储压力。

七、总结

本文全面介绍了 Spring Boot 与 ELK 的整合过程,包括环境准备、配置实现和日志可视化的具体步骤。通过 ELK 的强大功能,开发者可以轻松管理日志,提升系统的可观测性和运维效率。

ELK 是一个高度灵活的日志解决方案,但在实际应用中,需要根据项目需求灵活调整配置。如果您正在寻找一个强大的日志管理工具,ELK 是一个值得选择的方案。

希望本文对您有所帮助,如有问题,欢迎留言讨论!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/479115.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Kubeadm 安装 Kubernetes 高可用集群 v1.30.0

1、修改主机名&#xff08;各个节点&#xff09; hostnamectl set-hostname xxx2、hosts 文件加入主机名&#xff08;全部节点&#xff09; cat /etc/hosts 192.168.88.5 master1 192.168.88.6 master2 192.168.88.7 master3 192.168.88.8 node13、关闭防火墙&#xff08;全部…

网上蛋糕售卖店管理系(Java+SpringBoot+MySQL)

摘 要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装网上蛋糕售卖店管理系统软件来发挥其高效地信息处理的作用…

Ubuntu安装不同版本的opencv,并任意切换使用

参考&#xff1a; opencv笔记&#xff1a;ubuntu安装opencv以及多版本共存 | 高深远的博客 https://zhuanlan.zhihu.com/p/604658181 安装不同版本opencv及共存、切换并验证。_pkg-config opencv --modversion-CSDN博客 Ubuntu下多版本OpenCV共存和切换_ubuntu20如同时安装o…

自由学习记录(25)

只要有修改&#xff0c;子表就不用元表的参数了&#xff0c;用自己的参数&#xff08;只不过和元表里的那个同名&#xff09; 子表用__index“继承”了父表的值&#xff0c;此时子表仍然是空表 一定是创建这样一个同名的变量在原本空空的子表里&#xff0c; 传参要传具体的变…

1- 9 C 语言面向对象

面向对象的基本特性&#xff1a;封装&#xff0c;继承&#xff0c;多态 1.0 面向过程概念 当我们在编写程序时&#xff0c;通常采用以下步骤&#xff1a; 1. 将问题的解法分解成若干步骤 2. 使用函数分别实现这些步骤 3. 依次调用这些函数 这种编程风格的被称作 面向过程…

路面泥泞,坑洼,裂缝,路面损坏,马路牙检测 YOLO标记资源整理

数据集介绍 可识别常见的路面泥泞&#xff0c;坑洼&#xff0c;裂缝&#xff0c;路面损坏&#xff0c;马路牙等多种路面状况。 数据集分割 训练集89&#xff05; 2052图片 validation集8% 186图片 test集3% 78图片 预处理 自动定向&#xff1a; 已应用 自动调…

Jmeter中的测试片段和非测试原件

1&#xff09;测试片段 1--测试片段 功能特点 重用性&#xff1a;将常用的测试元素组合成一个测试片段&#xff0c;便于在多个线程组中重用。模块化&#xff1a;提高测试计划的模块化程度&#xff0c;使测试计划更易于管理和维护。灵活性&#xff1a;可以通过模块控制器灵活地…

Cocos编辑器

1、下载 下载地址&#xff1a;https://www.cocos.com/creator-download 2、编辑器界面介绍 官方链接&#xff1a;https://docs.cocos.com/creator/3.8/manual/zh/editor/ 3、项目结构 官方链接&#xff1a;https://docs.cocos.com/creator/3.8/manual/zh/getting-started/…

JAVA题目笔记(二十)Stream流综合练习+方法引用

一、数据过滤 import java.util.*; import java.util.stream.Collectors;public class Co {public static void main(String[] args) {List<Integer> listnew ArrayList<>();Collections.addAll(list,1,2,3,4,5,6,7,8,9,10);List<Integer> newlist list.str…

计算机操作系统——进程控制(Linux)

进程控制 进程创建fork&#xff08;&#xff09;函数fork() 的基本功能fork() 的基本语法fork() 的工作原理fork() 的典型使用示例fork() 的常见问题fork() 和 exec() 结合使用总结 进程终止与$进程终止的本质进程终止的情况正常退出&#xff08;Exit&#xff09;由于信号终止非…

摄像头原始数据读取——V4L2(mmap模式,V4L2_MEMORY_MMAP)

摄像头原始数据读取——V4L2(mmap模式,V4L2_MEMORY_MMAP) 内存映射模式&#xff0c;是将设备在内核态申请的用于存储视频数据的物理内存映射到用户空间&#xff0c;使得用户应用程序可以直接访问和操作设备数据物理内存&#xff0c;避免了数据的拷贝。因此采集速度较快&#x…

零地址挂页

零地址 如果我们有比较好的C编程基础&#xff0c;我们就会知道&#xff0c;我们在代码中定义了一个零地址或者空指针&#xff0c;那么它实际上会指向虚拟内存的零地址&#xff0c;多数操作系统&#xff0c;包括Win&#xff0c;在进程创建的时候&#xff0c;都会空出前64k的空间…

QT6学习第四天 感受QT的文件编译

QT6学习第四天 感受QT的文件编译 使用纯代码编写程序新建工程 使用其他编辑器纯代码编写程序并在命令行运行使用 .ui 表单文件生成界面使用自定义 C 窗口类使用现成的QT Designer界面类 使用纯代码编写程序 我们知道QT Creator中可以用拖拽的方式在 .ui 文件上布局&#xff0c…

windows安全中心,永久卸载工具分享

使用方法 2024Goby红队版工具分享&#xff0c;附2024年漏洞POC下载 下载链接&#xff1a; https://pan.quark.cn/s/4fc2712a2afc一路回车&#xff0c;选项Y即可 耐心等待几秒种&#xff0c;自动重启 此时打开windows安全中心&#xff0c;已经完全不能使用了&#xff0c;响应…

jvm核心组件介绍

1. 类加载器&#xff08;ClassLoader&#xff09;&#xff1a; • 想象它是一个快递员&#xff0c;负责把Java类&#xff08;.class文件&#xff09;这个“包裹”从磁盘这个“发货地”送到JVM内部这个“目的地”。类加载器确保每个类只被加载一次&#xff0c;并维护一个类的层级…

目标检测,图像分割,超分辨率重建

目标检测和图像分割 目标检测和图像分割是计算机视觉中的两个不同任务&#xff0c;它们的输出形式也有所不同。下面我将分别介绍这两个任务的输出。图像分割又可以分为&#xff1a;语义分割、实例分割、全景分割。 语义分割&#xff08;Semantic Segmentation&#xff09;&…

Python编程技巧:多变量赋值的优雅艺术

在Python编程的世界里&#xff0c;有许多令人惊叹的语法特性&#xff0c;而多变量赋值就像是一颗闪耀的明珠&#xff0c;它不仅让代码更优雅&#xff0c;还能提升程序的执行效率。今天我们就深入探讨这个看似简单却蕴含深意的编程技巧。 基础认识 传统的变量赋值方式&#xff…

CentOS 7 安装部署 KVM

1.关闭虚拟机 打开相关选项 打开虚拟机centos7 连接xshell 测试网络&#xff0c;现在就是没问题的&#xff0c;因为我们要使用网络源 安装 GNOME 桌面环境 安装KVM 模块 安装KVM 调试工具 构建虚拟机的命令行工具 qemu 组件,创建磁盘、启动虚拟机等 输入这条命令&#xff0c;…

微信小程序学习指南从入门到精通

&#x1f5fd;微信小程序学习指南从入门到精通&#x1f5fd; &#x1f51d;微信小程序学习指南从入门到精通&#x1f51d;✍前言✍&#x1f4bb;微信小程序学习指南前言&#x1f4bb;一、&#x1f680;文章列表&#x1f680;二、&#x1f52f;教程文章的好处&#x1f52f;1. ✅…

【C++】读取数量不定的输入数据

读取数量不定的输入数据 似乎是一个很实用的东西&#xff1f; 问题&#xff1a; 我们如何对用户输入的一组数&#xff08;事先不知道具体有多少个数&#xff09;求和&#xff1f; 这需要不断读取数据直至没有新的输入为止。&#xff08;所以我们的代码就是这样设计的&#x…