Java中日志采集框架-JUL、Slf4j、Log4j、Logstash

news2025/1/16 14:01:22

1. 日志采集

        日志采集是指在软件系统、网络设备、服务器或其他IT基础设施中自动收集日志文件和事件信息的过程。这些日志通常包含了时间戳、事件类型、源和目标信息、错误代码、用户操作记录等关键数据。日志采集的目的是为了监控系统运行状态、分析系统性能、审计用户行为、故障排查和安全监控等。

日志采集通常涉及以下几个关键步骤:

  1. 日志生成:系统或应用程序在运行过程中产生日志。

  2. 日志存储:日志被保存在本地文件系统、数据库或其他存储介质中。

  3. 日志收集:使用特定的工具或服务将分散在不同位置的日志集中到一个或多个中心位置。

  4. 日志传输:将收集的日志数据通过网络传输到日志分析系统或存储系统。

  5. 日志处理:对日志数据进行格式化、过滤、聚合等处理,以便于分析和存储。

  6. 日志分析:使用日志分析工具对收集的日志数据进行分析,以识别模式、趋势、异常行为或安全威胁。

  7. 日志监控和告警:实时监控日志数据,并在检测到特定事件或异常时触发告警。

  8. 日志保留:根据合规性和审计要求,日志数据需要被保留一定时间。

2. 日志框架

一些典型的日志框架如下:

  • JUL:java.util.logging(简称JUL)是Java平台的一部分,它是一个轻量级的日志框架,提供了日志记录的基础设施。JUL是Java SE标准库的一部分,因此不需要额外的库就可以在任何Java应用程序中使用它。

  • Logback:Logback是一个流行的Java日志框架,由Log4j的创始人Ceki Gülcü和另一位Log4j贡献者Sébastien Pennec设计。

  • Log4j:Log4j是一个由Apache软件基金会维护的开源日志记录工具,它是Java语言中广泛使用的日志框架之一。

  • Log4j2:作为Log4j的继任者,在性能和功能上都有显著的提升。

  • logstash:Logstash是一个开源的服务器端数据处理管道,它能够从多个来源采集数据,转换数据,然后将数据发送到“数据库”。

  • Slf4j:SLF4J(Simple Logging Facade for Java)是一个为Java提供简单日志抽象的API。它并不是一个具体的日志框架,而是一个日志门面,允许开发者在代码中使用统一的API来记录日志,而不必直接依赖于具体的日志实现(如Log4j、Logback或Java Util Logging等)

3. 实例

3.1 JUL

JDK1.4具有的原生日志框架(不建议使用)。

package com.xiaokai;

import java.util.logging.ConsoleHandler;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.util.logging.SimpleFormatter;

/**
 * Author:yang
 * Date:2024-11-19 10:25
 */
public class JULExample {
   private static final Logger logger = Logger.getLogger(JULExample.class.getName());

    public static void main(String[] args) {
        // 创建一个控制台处理器,并设置格式器
        ConsoleHandler consoleHandler = new ConsoleHandler();
        consoleHandler.setFormatter(new SimpleFormatter());
        logger.addHandler(consoleHandler);
        logger.setLevel(Level.INFO);// 设置日志级别为ALL,其他级别为FINEST、FINER、FINE、CONFIG、INFO、WARNING、SEVERE

        // 记录日志
        logger.log(Level.INFO, "This is an info message");
        logger.log(Level.SEVERE, "This is a severe message");
    }
}

测试结果:

十一月 19, 2024 10:30:44 上午 com.xiaokai.JULExample main
信息: This is an info message
十一月 19, 2024 10:30:44 上午 com.xiaokai.JULExample main
信息: This is an info message
十一月 19, 2024 10:30:44 上午 com.xiaokai.JULExample main
严重: This is a severe message
十一月 19, 2024 10:30:44 上午 com.xiaokai.JULExample main
严重: This is a severe message

3.2 Logback

它具有快速和通用的特性,可以在不同的环境下工作。Logback由三个模块组成:

  1. logback-core:构成logback-classic和logback-access的基础。要执行日志记录,需要logback-classic或logback-access。

  2. logback-classic:依靠logback-core提供日志记录服务,并且是log4j的改进版。它提供了更强大的日志功能,并且向下兼容log4j。它还支持SLF4J,可以在不修改代码的情况下将应用程序从一个日志框架切换到另一个日志框架。

  3. logback-access:为servlet容器(如Tomcat和Jetty)提供HTTP访问日志功能。

        Logback原生实现了Java的简单日志外观(SLF4J)API,这意味着开发人员可以针对SLF4J API编写日志代码,在部署时灵活地插入所需的日志框架。由于Logback原生实现了SLF4J,因此额外的SLF4J API层不会产生任何性能开销,这是Logback相对于其他框架的一点优势。

        Logback支持TRACE、DEBUG、INFO、WARN和ERROR五种日志级别。在本地开发时,通常将日志级别设置为DEBUG,这将提供详细的日志消息以供开发者使用。部署到生产环境时,通常将日志级别设置为ERROR,这是为了避免日志中充斥过多的调试信息。

3.2.1 添加依赖

<!-- Logback Classic Module -->
<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.2.3</version>
</dependency>

<!-- SLF4J API -->
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.30</version>
</dependency>

3.2.2 配置logback

创建一个名为logback.xml的配置文件,并将其放置在项目的src/main/resources目录下

<configuration>

    <!-- Console 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>

    <!-- File Appender -->
    <appender name="FILE" class="ch.qos.logback.core.FileAppender">
        <file>application.log</file>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
    </appender>

    <!-- Loggers -->
    <root level="info">
        <appender-ref ref="STDOUT" />
        <appender-ref ref="FILE" />
    </root>

</configuration>

这个配置定义了两个Appender:一个输出到控制台,一个输出到文件application.log

3.2.3 示例

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

@Component
public class MyService {

    private static final Logger logger = LoggerFactory.getLogger(MyService.class);

    public void doSomething() {
        logger.info("Doing something important");
    }
}

注:

  • SpringBoot项目,会自动加载logback-sprinng.xml命令的配置文件。

  • 一般情况下先加载logback-test.xml文件,没有会读取logback.xml文件。

  • 在application.yml文件中配置加载文件。

# application.yml logging: config: classpath:logback.xml

3.3 Slf4j

        SLF4J(Simple Logging Facade for Java)是一个为Java提供简单日志抽象的API。它并不是一个具体的日志框架,而是一个日志门面,允许开发者在代码中使用统一的API来记录日志,而不必直接依赖于具体的日志实现(如Log4j、Logback或Java Util Logging等)。

上述3.2 为slf4j+logback实现的日志输出示例。

3.4 Log4j

        Log4j是一个由Apache软件基金会维护的开源日志记录工具,它是Java语言中广泛使用的日志框架之一。以下是Log4j的一些关键特点和介绍:

  1. 灵活性和可配置性

    1. Log4j允许开发者通过配置文件(如log4j.propertieslog4j.xml)灵活地设置日志级别、输出格式和目的地。这些配置文件定义了Loggers(日志记录器)、Appenders(日志输出目的地)和Layouts(日志格式)。

  2. 多种日志级别

    1. Log4j支持多种日志级别,包括DEBUG、INFO、WARN、ERROR和FATAL,允许开发者根据需要控制日志的详细程度。

  3. 多种Appender支持

    1. Log4j提供了多种Appender,可以将日志输出到不同的地方,如控制台(ConsoleAppender)、文件(FileAppender)、滚动文件(RollingFileAppender)和数据库(JDBCAppender)等。

  4. Layout定制

    1. 通过Layout,Log4j允许开发者定制日志的输出格式,包括时间戳、日志级别、消息等。

  5. 性能

    1. 虽然Log4j1.x在性能上不如Log4j2,但它仍然是许多Java应用的常用日志框架,特别是在不需要极端性能要求的场景下。

  6. 安全性

    1. Log4j2相比于Log4j1.x在安全性方面有显著改进,例如,Log4j2中的JNDI支持更加安全,而Log4j1.x中的某些版本存在已知的安全漏洞,如Log4Shell(CVE-2021-44228)。

  7. 易用性

    1. Log4j通过简单的API使得在代码中插入日志语句变得容易,无需编写复杂的日志记录代码。

  8. 社区支持

    1. 作为一个成熟的开源项目,Log4j拥有活跃的社区支持,提供文档、教程和问题解答。

  9. 审计和调试

    1. Log4j不仅在开发周期中发挥作用,其丰富的日志记录功能也可以作为审计工具使用。

3.4.1 Maven依赖配置

在项目的pom.xml文件中添加Log4j的依赖:

<!-- Log4j2依赖 -->
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.20.0</version>
</dependency>

3.4.2 Log4j配置文件

在src/main/resources目录下创建log4j.properties文件:

# 设置根Logger的级别和输出目的地
log4j.rootLogger=DEBUG, stdout, file

# 配置控制台输出
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

# 配置文件输出
log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=logs/application.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

这个配置定义了两个Appender:一个输出到控制台,一个输出到文件application.log。

3.4.3 Java代码示例

创建一个Java类来使用Log4j记录日志:

import org.apache.log4j.Logger;

public class Log4jExample {
    private static final Logger logger = Logger.getLogger(Log4jExample.class);

    public static void main(String[] args) {
        logger.debug("这是一个调试信息");
        logger.info("这是一个普通信息");
        logger.warn("这是一个警告信息");
        logger.error("这是一个错误信息");
        logger.fatal("这是一个致命错误信息");
    }
}

3.5 Logstash

        Logstash是一个开源的服务器端数据处理管道,它能够从多个来源采集数据,转换数据,然后将数据发送到您最喜欢的“存储库”中。以下是Logstash的一些主要功能和特点:

  1. 集中、转换和存储数据

    1. Logstash能够动态地采集、转换和传输数据,不受格式或复杂度的影响。利用Grok从非结构化数据中派生出结构,从IP地址解码出地理坐标,匿名化或排除敏感字段,并简化整体处理过程。

  2. 输入、筛选和输出

    1. Logstash支持各种输入选择,可以同时从众多常用来源捕捉事件,如日志、指标、Web应用等。它还提供实时解析和转换数据的能力,以及众多输出选择,可以将数据发送到指定的地方。

  3. 可扩展插件生态系统

    1. Logstash提供超过200个插件,以及创建和贡献自己的灵活性。它采用可插拔框架,允许将不同的输入选择、筛选器和输出选择混合搭配、精心安排,让它们在管道中和谐地运行。

  4. 可靠性与安全性

    1. 如果Logstash节点发生故障,Logstash会通过持久化队列来保证至少将运行中的事件送达一次。那些未被正常处理的消息会被送往死信队列 (dead letter queue) 以便做进一步处理。此外,Logstash还能让您充分确保自己采集管道的安全性。

  5. 性能

    1. Logstash在性能上已经有很大提升,但与它的替代者们相比还是要慢很多的。它在大数据量的情况下可能会是个问题,特别是在资源消耗(默认的堆大小是1GB)方面。生产中写入Elasticsearch的速度可以达到5万/秒左右,但因为牵扯到过滤等操作,性能会有所降低。

  6. 社区支持

    1. Logstash是一个广泛采用的开源项目,拥有活跃的社区支持和大量的文档资源。

  7. 与Log4j的比较

    1. Logstash可以与Log4j配合使用,Log4j负责日志的生成和初步处理,而Logstash则负责日志的收集、解析和传输。Log4j配置文件中可以设置将日志输出到Logstash,Logstash再将这些日志数据传输到Elasticsearch中进行存储和分析。

3.5.1 基本示例

1. Logstash配置文件

        首先,我们需要创建一个Logstash配置文件,这里我们称之为logstash.conf。这个配置文件包含了输入(input)、过滤(filter)和输出(output)三个部分。

input {
  stdin { }
}
filter {
  grok {
    match => { "message" => "%{COMBINEDAPACHELOG}"}
  }
}
output {
  stdout { codec => rubydebug }
  elasticsearch {
    hosts => ["http://localhost:9200"] # Elasticsearch服务器地址
    index => "logstash-apache-logs-%{+YYYY.MM.dd}" # 索引名称,包含日期
  }
}

2. 运行Logstash

接下来,我们使用以下命令运行Logstash,并指定我们的配置文件:

bin/logstash -f logstash.conf

这个命令告诉Logstash使用我们提供的logstash.conf文件作为配置。

3. 输入日志数据

在运行Logstash的同时,我们可以向标准输入(stdin)输入日志数据。例如:

127.0.0.1 - frank [10/Oct/2000:13:55:36 -0700] "GET /apache_pb.gif HTTP/1.0" 200 2326

4. 查看处理结果

Logstash会将输入的日志数据通过grok插件解析,然后输出到标准输出(stdout)和Elasticsearch。在标准输出中,你会看到类似以下格式的JSON数据:

{
   "@version": "1",
   "host": "your-hostname",
   "@timestamp": "2023-11-20T12:39:38.514Z",
   "message": "127.0.0.1 - frank [10/Oct/2000:13:55:36 -0700] \"GET /apache_pb.gif HTTP/1.0\" 200 2326",
   "apache": {
      "clientip": "127.0.0.1",
      "ident": "-",
      "auth": "frank",
      "verb": "GET",
      "request": "/apache_pb.gif",
      "httpversion": "HTTP/1.0",
      "bytes": "2326",
      "referrer": "-",
      "agent": "-",
      "response": "200",
      "cookies": [],
      "xforwardedfor": [],
      "unresolvedaddress": null,
      "unresolvedhostname": null
   }
}

同时,这些数据也会被索引到Elasticsearch中,可以通过Kibana或其他Elasticsearch客户端工具来查询和分析这些日志数据。

3.5.2 采集Java程序日志作为输入

1. 添加依赖:在你的Java项目中添加Logback和Logstash encoder的依赖。如果你的项目是Maven项目,可以在pom.xml中添加以下依赖:

<!-- Logback Classic Module -->
<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.2.3</version>
</dependency>

<!-- Logstash Logback Encoder -->
<dependency>
    <groupId>net.logstash.logback</groupId>
    <artifactId>logstash-logback-encoder</artifactId>
    <version>5.3</version>
</dependency>

2. 配置Logback:在src/main/resources目录下创建logback-spring.xml文件,并配置一个appender将日志发送到Logstash:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <appender name="LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
        <!-- 配置Logstash服务地址 -->
        <destination>127.0.0.1:4560</destination>
        <!-- 日志输出编码 -->
        <encoder charset="UTF-8" class="net.logstash.logback.encoder.LoggingEventCompositeJsonEncoder">
            <providers>
                <timestamp>
                    <timeZone>UTC</timeZone>
                </timestamp>
                <pattern>
                    <pattern>
                        {
                        "logLevel": "%level",
                        "serviceName": "
${springAppName:-}",
                        "pid": "$
{PID:-}",
                        "thread": "%thread",
                        "class": "%logger{40}",
                        "rest": "%message"
                        }</pattern>
                </pattern>
            </providers>
        </encoder>
    </appender>
    <root level="DEBUG">
        <appender-ref ref="LOGSTASH" />
    </root>
</configuration>

3. 启动Logstash:配置Logstash监听TCP端口并接收日志:

input {
  tcp {
    mode => "server"
    host => "127.0.0.1"
    port => 4560
    codec => json_lines
  }
}
output {
  elasticsearch {
    hosts => "127.0.0.1:9200"
    index => "springboot-logstash-%{+YYYY.MM.dd}"
  }
}

4. 启动应用并查看日志:启动ava应用程序,日志将被发送到Logstash,并且Logstash会将这些日志存储到Elasticsearch中,在Kibana中查看和分析这些日志。

  不积跬步,无以至千里 --- xiaokai

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

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

相关文章

ansible从入门到精通(完整篇)

ansible从入门到精通&#xff08;完整篇&#xff09; 转自ansible从入门到精通&#xff08;完整篇&#xff09; 文章目录 01 Ansible介绍与安装 1. 介绍 Ansible 1.1 什么是 Ansible?1.2 Ansible 无需代理1.3 Ansible 方式 2. 安装 Ansible 2.1 控制节点2.2 受管主机2.3…

Python自学之Colormaps指南

目录 1.色彩映射表&#xff08;Colormaps&#xff09;是什么&#xff1f; 2.Matplotlib中的色彩映射表类型 2.1同色渐变&#xff08;Sequential Colormaps&#xff09; 2.2双色渐变&#xff08;Divergence Colormaps&#xff09; 2.3定性色彩&#xff08;Qualitative Col…

CentOS 环境下通过 YUM 安装软件

操作场景 为提升用户在云服务器上的软件安装效率&#xff0c;减少下载和安装软件的成本&#xff0c;腾讯云提供了 YUM 下载源。在 CentOS 环境下&#xff0c;用户可通过 yum 命令快速安装软件。对于 YUM 下载源&#xff0c;用户不需要添加软件源&#xff0c;可以直接安装软件包…

手机远程控制电脑,让办公更快捷

在数字化办公的浪潮下&#xff0c;远程控制软件已成为连接工作与生活的桥梁。它使得用户能够通过一台设备&#xff08;主控端&#xff09;来操作另一台设备&#xff08;被控端&#xff09;&#xff0c;无论它们是否位于同一局域网内。这种软件广泛应用于远程办公、手机远程控制…

WebRTC实现双端音视频聊天(Vue3 + SpringBoot)

目录 概述 相关概念 双端连接整体实现步骤概述 文章代码实现注意点 STUN和TURN服务器的搭建 开发过程描述 后端开发流程 前端开发流程 效果演示 Gitee源码地址 概述 文章描述使用WebRTC技术实现一对一音视频通话。 由于设备摄像头限制&#xff08;一台电脑作测试无法…

[C++]:C++11(二)

1. 左值与右值 1.1 左值与右值的概念 左值&#xff1a;左值本质上是一个表示数据的表达式&#xff0c;常见的如变量名或者解引用后的指针等形式。它具备以下显著特点&#xff1a; 可被取地址&#xff1a;能够通过取地址操作符 & 获取其内存地址&#xff0c;这意味着它在内…

Acme PHP - Let‘s Encrypt

Lets Encrypt是一个于2015年三季度推出的数字证书认证机构&#xff0c;旨在以自动化流程消除手动创建和安装证书的复杂流程&#xff0c;并推广使万维网服务器的加密连接无所不在&#xff0c;为安全网站提供免费的SSL/TLS证书。 使用PHP来更新证书&#xff1a; Acme PHP | Rob…

探索 HTML 和 CSS 实现的 3D旋转相册

效果演示 这段HTML与CSS代码创建了一个包含10张卡片的3D旋转效果&#xff0c;每张卡片都有自己的边框颜色和图片。通过CSS的3D变换和动画&#xff0c;实现了一个动态的旋转展示效果 HTML <div class"wrapper"><div class"inner" style"-…

Cargo Rust 的包管理器

Cargo->Rust 的包管理器 Cargi简介Cargo 的主要功能1. 创建项目2. 管理依赖3. 构建项目4. 运行项目5. 测试代码6. 检查代码7. 生成文档8. 发布和分享包 Cargo 的核心文件1. Cargo.toml2. Cargo.lock **Cargo 的生态系统** 常用命令总结Hello, Cargo! 示例 Cargi简介 Cargo …

代码随想录算法训练营第三十五天| 01背包问题 二维 、01背包问题 一维、416. 分割等和子集 。c++转java

背包理论基础 视频地址&#xff1a; 带你学透0-1背包问题&#xff01;| 关于背包问题&#xff0c;你不清楚的地方&#xff0c;这里都讲了&#xff01;| 动态规划经典问题 | 数据结构与算法_哔哩哔哩_bilibili 01背包问题 二维 题目我是在Acwing上面做的&#xff0c;思路可以…

亚马逊云科技宣布新推出Elasticahe for Redis的 Valkey缓存

Amazon ElastiCache 宣布支持 Valkey&#xff0c;与其他支持的引擎相比&#xff0c;无服务器的价格低 33%&#xff0c;基于节点的价格低 20%。使用 ElastiCache Serverless for Valkey&#xff0c;客户可以在一分钟内创建缓存&#xff0c;并且起步价低至每月 6 USD。Valkey 是由…

SpringBoot3.x.x整合Ehcache3 实例(入门踩坑教程)

近期尝试了一下 SpringBoot 3.3.5 JDK17 Ehcache3.10.8整合 注意&#xff0c;这个版本的boot&#xff0c;提出了公用的缓存模板&#xff0c;Spring官网有相关介绍&#xff0c;整合ehcache需要使用jcache。 老版本的3.0版本以下整合&#xff0c;我这里就不参与了&#xff0c;可以…

跨平台WPF框架Avalonia教程 十六

SelectableTextBlock 可选文本块 SelectableTextBlock 块是一个用于显示文本的标签&#xff0c;允许选择和复制文本。它可以显示多行&#xff0c;并且可以完全控制所使用的字体。 有用的属性​ 您可能最常使用这些属性&#xff1a; 属性描述SelectionStart当前选择的起始字…

每日一练:【优先算法】双指针之移动零(easy)

双指针概念介绍 常见的双指针有两种形式&#xff0c;一种是对撞指针&#xff0c;一种是左右指针。 对撞指针&#xff1a;一般用于顺序结构中&#xff0c;也称左右指针。 • 对撞指针从两端向中间移动。一个指针从最左端开始&#xff0c;另一个从最右端开始&#xff0c;然后逐渐…

ASP.NET Core Webapi 返回数据的三种方式

ASP.NET Core为Web API控制器方法返回类型提供了如下几个选择&#xff1a; Specific type IActionResult ActionResult<T> 1. 返回指定类型&#xff08;Specific type&#xff09; 最简单的API会返回原生的或者复杂的数据类型&#xff08;比如&#xff0c;string 或者…

【JAVA】使用mybatis plus查询数据库中的geometry字段为null

目录 问题描述&#xff1a; 原码&#xff1a; 实体类&#xff1a; 接口&#xff1a; 解决方法&#xff1a; 1、创建Handle 2、配置handle让mybatis-plus能够识别 相关代码&#xff1a; 问题描述&#xff1a; 在 MyBatis Plus 中&#xff0c;查询的 geometry 字段在数据库…

51c自动驾驶~合集28

我自己的原文哦~ https://blog.51cto.com/whaosoft/12030824 #自动驾驶建图的统一矢量先验地图编码 高德地图&西交 | 先验驾驶 论文链接&#xff1a;https://arxiv.org/pdf/2409.05352 写在前面&笔者的个人理解 最近出现了很多先验地图的论文&#xff0c;高德地图…

【全面解读】Apache SeaTunnel常见问题全攻略

使用SeaTunnel需要安装Spark或者Flink这样的引擎么&#xff1f; 不需要&#xff0c;SeaTunnel 支持 Zeta、Spark 和 Flink 作为同步引擎的选择&#xff0c;您可以选择之一就行&#xff0c;社区尤其推荐使用 Zeta 这种专为同步场景打造的新一代超高性能同步引擎。Zeta 被社区用…

Spring Boot3.x自动配置不生效的排查与解决:IDEA 文件夹命名导致的问题

在使用Spring Boot搭建多模块项目时&#xff0c;需要使用到自动配置功能&#xff0c;把一些通用功能封装成模块后通过 META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports 文件注册配置类。然而&#xff0c;最近遇到一个奇怪的问题&#xff1a…

JavaSE(十四)——文件操作和IO

文章目录 文件操作和IO文件相关概念Java操作文件文件系统操作文件内容操作字节流FileOutputStreamFileInputStream代码演示 字符流FileWriterFileReader代码演示 缓冲流转换流 案例练习 文件操作和IO 文件相关概念 文件 通常指的是包含用户数据的文件&#xff0c;如文本文件、…