如何在项目中快速引入Logback日志并搭配ELK使用

在Java项目中引入日志系统是一件非常重要的事情,它可以帮助我们记录程序的运行状态、调试信息和错误信息。Logback是一个非常流行的日志框架,具有高性能和灵活的配置能力。本文将介绍如何在项目中快速引入Logback日志,并说明为什么要使用Logback,以及如何与ELK(Elasticsearch、Logstash、Kibana)套件搭配使用以达到更好的效果。

为什么要引入Logback

  1. 高性能:Logback的设计目标之一就是高性能,特别是在高并发环境下的表现非常优秀。
  2. 灵活的配置:通过配置文件,可以灵活地定制日志的格式、输出目的地、日志级别等。
  3. 与SLF4J集成:Logback是SLF4J的原生实现,可以方便地与其他日志框架(如Log4j)进行无缝切换。
  4. 丰富的功能:支持多种Appender(如文件、控制台、数据库等),并提供了过滤器、格式化等丰富的功能。

快速引入Logback

1. 添加依赖

首先,在项目的pom.xml中添加Logback的依赖(如果使用的是Maven):

<dependencies><!-- SLF4J API --><dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId><version>1.7.36</version></dependency><!-- Logback Classic --><dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.11</version></dependency>
</dependencies>

如果使用的是Gradle,可以在build.gradle中添加以下内容:

dependencies {implementation 'org.slf4j:slf4j-api:1.7.36'implementation 'ch.qos.logback:logback-classic:1.2.11'
}

2. 配置Logback

在项目的src/main/resources目录下创建logback.xml文件,这是Logback的默认配置文件。一个简单的配置示例如下:

<configuration><!-- 控制台Appender --><appender name="STDOUT" 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 --><appender name="FILE" class="ch.qos.logback.core.FileAppender"><file>logs/app.log</file><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern></encoder></appender><!-- 设置日志级别 --><root level="debug"><appender-ref ref="STDOUT"/><appender-ref ref="FILE"/></root></configuration>

3. 在代码中使用Logback

在Java代码中使用SLF4J API进行日志记录:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;public class Main {private static final Logger logger = LoggerFactory.getLogger(Main.class);public static void main(String[] args) {logger.info("This is an info message");logger.debug("This is a debug message");logger.error("This is an error message");}
}

搭配ELK三剑客

ELK套件由Elasticsearch、Logstash和Kibana组成,可以帮助我们集中管理和分析日志。我们可以将Logback的日志发送到Logstash,然后由Logstash传输到Elasticsearch,最后通过Kibana进行可视化分析。

1. 搭配Logstash

首先,添加Logstash的Logback插件依赖。在pom.xml中添加:

<dependency><groupId>net.logstash.logback</groupId><artifactId>logstash-logback-encoder</artifactId><version>7.0</version>
</dependency>

接着,在logback.xml中配置将日志发送到Logstash:

<configuration><!-- 控制台Appender --><appender name="STDOUT" 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 --><appender name="FILE" class="ch.qos.logback.core.FileAppender"><file>logs/app.log</file><encoder><pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern></encoder></appender><!-- Logstash 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="debug"><appender-ref ref="STDOUT"/><appender-ref ref="FILE"/><appender-ref ref="LOGSTASH"/></root>
</configuration>

2. 配置Logstash

在Logstash中配置input和output,创建一个Logstash配置文件(如logstash.conf):

input {tcp {port => 5044codec => json}
}output {elasticsearch {hosts => ["http://localhost:9200"]index => "app-logs-%{+YYYY.MM.dd}"}
}

3. 启动ELK

确保Elasticsearch和Kibana已经启动,并运行Logstash:

logstash -f logstash.conf

4. 在Kibana中查看日志

访问Kibana(通常是http://localhost:5601),在Kibana中创建索引模式(如app-logs-*),然后可以在Discover标签中查看和分析日志。

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

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

相关文章

Aigtek电压放大器的主要作用是什么

电压放大器是一种重要的电子设备&#xff0c;用于放大电压信号。它在许多电子系统和应用中发挥着关键的作用。本文将详细介绍电压放大器的主要作用和工作原理。 电压放大器是一种电子电路&#xff0c;它可以将输入信号的电压放大为更大的输出电压。放大器通过增加输入信号的幅度…

【CS.DS】数据结构 —— 图: 图的相关概念大全

文章目录 1 图的类型2 图的基本术语References 1 图的类型 图是一种数据结构&#xff0c;由节点&#xff08;顶点&#xff09;和边组成。图可以用来表示各种网络结构&#xff0c;如社交网络、交通网络、计算机网络等。根据边的性质&#xff0c;图可以分为以下几种类型&#xf…

.git目录解读

在执行 git init 命令时&#xff0c;Git 会在当前目录中创建一个名为 .git 的目录。该目录包含 Git 所需的所有元数据和对象&#xff0c;用于版本控制。以下是 .git 目录结构的示意图&#xff0c;并附有每个目录和文件的作用说明&#xff1a; .git #…

使用Apache Flink实现实时数据同步与清洗:MySQL和Oracle到目标MySQL的ETL流程

使用Apache Flink实现实时数据同步与清洗&#xff1a;MySQL和Oracle到目标MySQL的ETL流程 实现数据同步的ETL&#xff08;抽取、转换、加载&#xff09;过程通常涉及从源系统&#xff08;如数据库、消息队列或文件&#xff09;中抽取数据&#xff0c;进行必要的转换&#xff0c…

Windows C++ 应用软件开发从入门到精通详解

目录 1、引言 2、IDE 开发环境介绍 2.1、Visual Studio 2.2、QT Creator 3、Windows 平台实用小工具介绍 3.1、代码编辑器 VSCode 3.2、代码查看编辑器 Source Insight 3.3、文本编辑器 Notepad 3.4、文件搜索工具 Everything 4、 C语言特性 4.1、熟悉泛型编程 4.…

恭喜行云绽放,24年再度荣获国家鼓励的企业软件证书

在刚刚过去的五月份&#xff0c;行云绽放再次传来一个好消息&#xff0c;那就是2024年行云绽放再度荣获国家鼓励的企业软件证书。 什么是国家鼓励的企业软件证书&#xff1f; 国家鼓励的企业软件证书被称为“国家鼓励的软件企业证书”&#xff0c;这一证书由中国软件行业协会…

LangChain轻松入门和开发实践

LangChain是一个开发语言模型应用的框架。 LangChain能够简化开发与语言模型工作流中的复杂部分&#xff0c;帮助开发人员能够更轻松地进行开发&#xff0c;并定制满足需求的应用。 LangChain有两大优点&#xff0c;一是它能将外部数据&#xff0c;如文件、其他应用、API数据等…

kylinos 国产操作系统离线安装firefox 麒麟操作系统安装新版本firefox

1. 火狐地址&#xff1a; 下载 Firefox 浏览器&#xff0c;这里有简体中文及其他 90 多种语言版本供您选择 2. 选择&#xff1a; 3. 下载完之后&#xff0c;上传到离线机器 4. 解压缩&#xff1a; tar -xvjf firefox-127.0.1.tar.bz2 5. 去点击解压后的文件夹&#xff0c;找…

MySQL插入并更新

1. 基本批量插入 INSERT INTO table_name (column1, column2) VALUES (value1_1, value1_2), (value2_1, value2_2), (value3_1, value3_2); 2. 批量插入并更新&#xff08;Upsert&#xff09; 这个语法表示如果 column1 是唯一键或主键&#xff0c;当插入操作遇到重复值时…

SpringCloud Alibaba Sentinel 流量控制之流控效果实践总结

当 QPS 超过某个阈值的时候&#xff0c;则采取措施进行流量控制。流量控制的效果包括以下几种&#xff1a;直接拒绝、Warm Up、匀速排队/排队等待。对应 FlowRule 中的 controlBehavior 字段。 注意&#xff1a;若使用除了直接拒绝之外的流量控制效果&#xff0c;则调用关系限流…

计算机视觉与深度学习实战,Python为工具,基于主成分分析的图像压缩和重建

一、引言 在信息技术和互联网飞速发展的今天,图像数据呈现出爆炸式的增长。然而,图像数据的传输和存储需要消耗大量的资源。因此,图像压缩技术成为了解决这一问题的关键。近年来,深度学习在计算机视觉领域取得了显著的成果,为图像压缩提供了新的思路和方法。主成分分析(P…

第六十五天打卡 | 卡码网 99 岛屿数量(深搜版)、卡码网 99 岛屿数量(广搜版)、卡码网 100 岛屿的最大面积

卡码网 99 岛屿数量(深搜版) 基本就是回溯算法 翻版了 #include <iostream> #include <vector>using namespace std;int dir[4][2] {-1, 0, 1, 0, 0, 1, 0, -1};void dfs(vector<vector<int>>& grid, vector<vector<int>>& visi…

如何有效管理信息技术课堂

有效管理信息技术课堂是确保学生学习效果、维护课堂秩序和提升学生兴趣的关键。以下是一些详细的方法和策略&#xff0c;旨在帮助教师更好地管理信息技术课堂&#xff1a; 一、制定明确的课堂规则 强调课堂纪律&#xff1a;确保学生明确了解并遵守课堂纪律&#xff0c;如准时…

ROS2学习资源

2024.6.21 快放暑假了&#xff01;简单计划一下暑假的学习内容。 首先是ROS2&#xff0c;学习资源&#xff1a; 官方文档&#xff1a;ROS 2 Documentation — ROS 2 Documentation: Humble documentation B站赵虚左老师的教程&#xff1a; ROS2理论与实践_哔哩哔哩_bilibil…

long long ago

一、long 众所周知&#xff0c;英文单词 long&#xff0c;表示长,长的。 但是&#xff0c;还有很多你不知道到的东西&#xff0c;根据英文单词首字母象形原则&#xff0c;我们可以做一下单词long结构分析&#xff1a; long l长 ong长 什么意思&#xff1f;就是说首字线 l…

H3C路由器密码恢复方法

H3C的路由器需要先关闭电源&#xff0c;重新启动路由器&#xff0c;注意终端上显示 press CTRLB to enter extended boot menu 的时候&#xff0c;请迅速按下ctrlB&#xff0c;这样将进入扩展启动选项。接着&#xff0c;你就可以进入路由器视图&#xff1a; 1.低端H3C设备 重启…

英语(1)-读音规则-连读-失去爆破

元音&#xff1a; a ,e ,i ,o, u 发音气流不受阻 辅音&#xff1a;b c d f g h j k l m n p q r s t v w x y z 发音气流受阻 爆破音&#xff1a;完全阻断气流并随之释放产生 清音&#xff1a;p t k 浊音&#xff1a;b d g 1.连读&#xff1a; 11.辅音元…

Javascript高级程序设计(第四版)--学习记录

var关键字&#xff1a;定义变量同时可以进行赋值 var message"hello" message 10 可以改变保存的值&#xff0c;也可以改变值的类型&#xff0c;但是不推荐这样写。 var声明的变量会成为包含它的函数的局部变量。 function test(){ var message "hello";…

STM32 I2C总线锁死原因及解决方法

本文介绍STM32 I2C总线锁死原因及解决方法。 在使用STM32 I2C总线操作外设时&#xff0c;有时会遇到I2C总线锁死&#xff08;I2C总线为Busy状态&#xff09;的问题&#xff0c;即便复位MCU也无法解决&#xff0c;本文介绍其锁死的原因和解决方法&#xff0c;并给出相应的参考代…

pdf转图片转换器,pdf转图片的工具

在日常的工作和学习中&#xff0c;我们经常会遇到需要将PDF文件转换为图片格式的情况。那么&#xff0c;如何才能将PDF格式转换为图片格式呢&#xff1f;今天&#xff0c;我将为大家介绍几种简单易用的方法&#xff0c;帮助大家轻松实现PDF转图片。 打开“轻云pdf处理官网网站”…