欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Boot集成SLF4j從基礎(chǔ)到高級(jí)實(shí)踐(最新推薦)

 更新時(shí)間:2025年05月13日 16:56:34   作者:Clf丶憶笙  
SLF4j (Simple Logging Facade for Java) 是一個(gè)日志門面(Facade),不是具體的日志實(shí)現(xiàn),這篇文章主要介紹了Spring Boot集成SLF4j從基礎(chǔ)到高級(jí)實(shí)踐(最新推薦),需要的朋友可以參考下

一、日志框架概述與SLF4j簡介

1.1 為什么需要日志框架

在軟件開發(fā)中,日志記錄是至關(guān)重要的組成部分。想象一下你正在開發(fā)一個(gè)電商系統(tǒng):

  • 用戶下單失敗時(shí),你需要知道具體原因
  • 系統(tǒng)性能出現(xiàn)瓶頸時(shí),你需要追蹤耗時(shí)操作
  • 生產(chǎn)環(huán)境出現(xiàn)問題時(shí),你需要排查錯(cuò)誤根源

如果沒有良好的日志系統(tǒng),就像在黑暗中摸索,無法快速定位和解決問題。

1.2 主流日志框架對(duì)比

框架名稱類型特點(diǎn)適用場(chǎng)景
Log4j實(shí)現(xiàn)Apache出品,功能強(qiáng)大,配置靈活傳統(tǒng)Java項(xiàng)目
Log4j2實(shí)現(xiàn)Log4j升級(jí)版,性能更好,支持異步高性能要求的系統(tǒng)
Logback實(shí)現(xiàn)SLF4j原生實(shí)現(xiàn),性能優(yōu)異Spring Boot默認(rèn)
JUL (java.util.logging)實(shí)現(xiàn)JDK內(nèi)置,功能簡單小型應(yīng)用或JDK環(huán)境限制時(shí)
SLF4j門面提供統(tǒng)一接口,不負(fù)責(zé)具體實(shí)現(xiàn)需要靈活切換日志實(shí)現(xiàn)的場(chǎng)景

1.3 SLF4j的核心價(jià)值

SLF4j (Simple Logging Facade for Java) 是一個(gè)日志門面(Facade),不是具體的日志實(shí)現(xiàn)。它類似于JDBC,提供統(tǒng)一的API,底層可以連接不同的數(shù)據(jù)庫驅(qū)動(dòng)。

門面模式的優(yōu)勢(shì)

  • 解耦:業(yè)務(wù)代碼不依賴具體日志實(shí)現(xiàn)
  • 靈活:可隨時(shí)切換底層日志框架
  • 統(tǒng)一:項(xiàng)目中使用一致的日志API

二、Spring Boot默認(rèn)日志配置

2.1 Spring Boot的日志選擇

Spring Boot默認(rèn)使用SLF4j + Logback組合:

  • SLF4j:提供統(tǒng)一的日志API
  • Logback:作為SLF4j的默認(rèn)實(shí)現(xiàn),性能優(yōu)于Log4j

2.2 基本使用示例

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@RestController
public class OrderController {
    // 使用SLF4j的LoggerFactory獲取Logger實(shí)例
    private static final Logger logger = LoggerFactory.getLogger(OrderController.class);
    @GetMapping("/order/{id}")
    public String getOrder(@PathVariable String id) {
        // 不同級(jí)別的日志記錄
        logger.trace("追蹤訂單查詢,訂單ID: {}", id);  // 最詳細(xì)的日志
        logger.debug("調(diào)試信息-訂單ID: {}", id);      // 調(diào)試信息
        logger.info("查詢訂單,訂單ID: {}", id);       // 業(yè)務(wù)信息
        logger.warn("訂單查詢參數(shù)過長,ID: {}", id);    // 警告信息
        if(id.length() > 20) {
            logger.error("訂單ID格式異常: {}", id);    // 錯(cuò)誤信息
            throw new IllegalArgumentException("非法的訂單ID");
        }
        return "訂單詳情";
    }
}

2.3 日志級(jí)別詳解

SLF4j定義了6種日志級(jí)別(從低到高):

級(jí)別含義使用場(chǎng)景默認(rèn)是否輸出
TRACE追蹤最詳細(xì)的日志信息,記錄程序每一步執(zhí)行
DEBUG調(diào)試調(diào)試信息,開發(fā)階段使用
INFO信息重要的業(yè)務(wù)過程信息
WARN警告潛在的問題,不影響系統(tǒng)運(yùn)行
ERROR錯(cuò)誤錯(cuò)誤信息,影響部分功能
FATAL致命導(dǎo)致系統(tǒng)崩潰的嚴(yán)重錯(cuò)誤是(Logback無此級(jí)別,會(huì)映射為ERROR)

三、SLF4j配置文件詳解

3.1 默認(rèn)配置與自定義

Spring Boot默認(rèn)會(huì)在classpath下查找以下日志配置文件:

  • logback-spring.xml (推薦)
  • logback.xml

為什么推薦使用logback-spring.xml

因?yàn)樗С諷pring Boot的Profile特性,可以根據(jù)不同環(huán)境加載不同配置。

3.2 完整配置文件解析

以下是一個(gè)完整的logback-spring.xml示例,我們分段解析:

<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="30 seconds">
    <!-- 定義變量 -->
    <property name="LOG_HOME" value="./logs" />
    <property name="APP_NAME" value="my-application" />
    <property name="LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n" />
    <!-- 控制臺(tái)輸出 -->
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>${LOG_PATTERN}</pattern>
            <charset>UTF-8</charset>
        </encoder>
        <!-- 控制臺(tái)只輸出INFO及以上級(jí)別 -->
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>INFO</level>
        </filter>
    </appender>
    <!-- 滾動(dòng)文件輸出 -->
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${LOG_HOME}/${APP_NAME}.log</file>
        <encoder>
            <pattern>${LOG_PATTERN}</pattern>
            <charset>UTF-8</charset>
        </encoder>
        <!-- 滾動(dòng)策略 -->
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!-- 按日期和大小滾動(dòng) -->
            <fileNamePattern>${LOG_HOME}/${APP_NAME}-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
            <!-- 單個(gè)文件最大100MB -->
            <maxFileSize>100MB</maxFileSize>
            <!-- 保留30天日志 -->
            <maxHistory>30</maxHistory>
            <!-- 總大小不超過5GB -->
            <totalSizeCap>5GB</totalSizeCap>
        </rollingPolicy>
    </appender>
    <!-- 異步日志 -->
    <appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender">
        <!-- 不丟失日志的閾值,默認(rèn)256 -->
        <queueSize>512</queueSize>
        <!-- 添加附加的appender -->
        <appender-ref ref="FILE" />
    </appender>
    <!-- 日志級(jí)別設(shè)置 -->
    <root level="INFO">
        <appender-ref ref="CONSOLE" />
        <appender-ref ref="ASYNC" />
    </root>
    <!-- 特定包/類日志級(jí)別 -->
    <logger name="com.example.demo.dao" level="DEBUG" />
    <logger name="org.springframework" level="WARN" />
    <!-- 生產(chǎn)環(huán)境特定配置 -->
    <springProfile name="prod">
        <root level="WARN">
            <appender-ref ref="CONSOLE" />
            <appender-ref ref="ASYNC" />
        </root>
    </springProfile>
    <!-- 開發(fā)環(huán)境特定配置 -->
    <springProfile name="dev">
        <root level="DEBUG">
            <appender-ref ref="CONSOLE" />
        </root>
    </springProfile>
</configuration>

3.3 配置元素詳解

3.3.1 屬性定義(Properties)

<property name="LOG_HOME" value="./logs" />
屬性說明示例值必要性
name屬性名LOG_HOME必填
value屬性值./logs必填
scope作用域context/system可選

3.3.2 輸出源(Appender)

1. 控制臺(tái)輸出(ConsoleAppender)

<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
        <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </encoder>
</appender>

2. 文件輸出(RollingFileAppender)

<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>${LOG_HOME}/${APP_NAME}.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
        <fileNamePattern>${LOG_HOME}/${APP_NAME}-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
        <maxFileSize>100MB</maxFileSize>
        <maxHistory>30</maxHistory>
    </rollingPolicy>
</appender>

滾動(dòng)策略對(duì)比

策略類說明適用場(chǎng)景
TimeBasedRollingPolicy按時(shí)間滾動(dòng)需要按天/小時(shí)分割日志
SizeBasedTriggeringPolicy按大小滾動(dòng)需要限制單個(gè)日志文件大小
SizeAndTimeBasedRollingPolicy時(shí)間和大小雙重策略既按時(shí)間又按大小分割

3.3.3 日志格式(Pattern)

日志格式由轉(zhuǎn)換符組成,常用轉(zhuǎn)換符:

策略類說明適用場(chǎng)景
TimeBasedRollingPolicy按時(shí)間滾動(dòng)需要按天/小時(shí)分割日志
SizeBasedTriggeringPolicy按大小滾動(dòng)需要限制單個(gè)日志文件大小
SizeAndTimeBasedRollingPolicy時(shí)間和大小雙重策略既按時(shí)間又按大小分割

3.3.4 過濾器(Filter)

<filter class="ch.qos.logback.classic.filter.LevelFilter">
    <level>ERROR</level>
    <onMatch>ACCEPT</onMatch>
    <onMismatch>DENY</onMismatch>
</filter>

常用過濾器:

過濾器類功能參數(shù)
LevelFilter精確匹配級(jí)別level, onMatch, onMismatch
ThresholdFilter閾值過濾,高于等于該級(jí)別才記錄level
EvaluatorFilter使用表達(dá)式過濾evaluator

3.3.5 異步日志(AsyncAppender)

<appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender">
    <queueSize>512</queueSize>
    <discardingThreshold>0</discardingThreshold>
    <appender-ref ref="FILE" />
</appender>

參數(shù)說明

參數(shù)說明默認(rèn)值建議值
queueSize隊(duì)列大小256512-2048
discardingThreshold當(dāng)隊(duì)列剩余容量小于此值時(shí),丟棄TRACE/DEBUG日志queueSize/50(不丟棄)
includeCallerData是否包含調(diào)用者信息false生產(chǎn)環(huán)境false(性能考慮)

四、高級(jí)特性與最佳實(shí)踐

4.1 MDC (Mapped Diagnostic Context)

MDC用于在日志中保存線程上下文信息,非常適合Web請(qǐng)求跟蹤。

示例:添加請(qǐng)求ID到日志

import org.slf4j.MDC;
@RestController
public class OrderController {
    @GetMapping("/order/{id}")
    public String getOrder(@PathVariable String id) {
        // 設(shè)置MDC值
        MDC.put("requestId", UUID.randomUUID().toString());
        MDC.put("userId", "user123");
        try {
            logger.info("查詢訂單: {}", id);
            // 業(yè)務(wù)邏輯...
            return "訂單詳情";
        } finally {
            // 清除MDC
            MDC.clear();
        }
    }
}

logback配置中引用MDC

<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%X{requestId}] %-5level %logger{36} - %msg%n</pattern>

4.2 日志性能優(yōu)化

參數(shù)化日志

避免字符串拼接,使用占位符:

// 不推薦
logger.debug("User " + userId + " login from " + ip);
// 推薦
logger.debug("User {} login from {}", userId, ip);

isXXXEnabled判斷

對(duì)于高開銷的日志:

if(logger.isDebugEnabled()) {
    logger.debug("Large data: {}", expensiveOperation());
}

異步日志

如前面示例,使用AsyncAppender減少I/O阻塞

4.3 多環(huán)境配置

利用Spring Profile實(shí)現(xiàn)環(huán)境差異化配置:

<!-- 開發(fā)環(huán)境 -->
<springProfile name="dev">
    <root level="DEBUG">
        <appender-ref ref="CONSOLE" />
    </root>
</springProfile>
<!-- 生產(chǎn)環(huán)境 -->
<springProfile name="prod">
    <root level="INFO">
        <appender-ref ref="FILE" />
        <appender-ref ref="SENTRY" />
    </root>
</springProfile>

4.4 日志監(jiān)控與告警

集成Sentry實(shí)現(xiàn)錯(cuò)誤監(jiān)控:

<!-- Sentry Appender -->
<appender name="SENTRY" class="io.sentry.logback.SentryAppender">
    <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
        <level>ERROR</level>
    </filter>
</appender>

五、常見問題與解決方案

5.1 日志沖突問題

問題現(xiàn)象:SLF4j報(bào)錯(cuò)SLF4J: Class path contains multiple SLF4J bindings

解決方案:使用mvn dependency:tree檢查依賴,排除多余的日志實(shí)現(xiàn)

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-logging</artifactId>
        </exclusion>
    </exclusions>
</dependency>

5.2 日志文件不生成

檢查步驟

  • 確認(rèn)配置文件位置正確(resources目錄下)
  • 檢查文件路徑是否有寫入權(quán)限
  • 查看是否有異常日志輸出
  • 確認(rèn)Appender被引用<appender-ref ref="FILE" />

5.3 日志級(jí)別不生效

可能原因

  • 配置被覆蓋(檢查多個(gè)配置文件)
  • 包路徑配置錯(cuò)誤
  • 配置修改后未重新加載(設(shè)置scan="true"

六、實(shí)戰(zhàn)案例:電商系統(tǒng)日志設(shè)計(jì)

6.1 日志分類設(shè)計(jì)

日志類型級(jí)別輸出目標(biāo)內(nèi)容
訪問日志INFOaccess.log記錄所有HTTP請(qǐng)求
業(yè)務(wù)日志INFObiz.log核心業(yè)務(wù)操作
錯(cuò)誤日志ERRORerror.log系統(tǒng)異常和錯(cuò)誤
SQL日志DEBUGsql.logSQL語句和參數(shù)
性能日志INFOperf.log接口耗時(shí)統(tǒng)計(jì)

6.2 完整配置示例

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- 公共屬性 -->
    <property name="LOG_HOME" value="/var/logs/ecommerce" />
    <property name="APP_NAME" value="ecommerce" />
    <!-- 公共Pattern -->
    <property name="COMMON_PATTERN" 
              value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%X{requestId}] [%thread] %-5level %logger{36} - %msg%n" />
    <!-- 控制臺(tái)輸出 -->
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>${COMMON_PATTERN}</pattern>
        </encoder>
    </appender>
    <!-- 訪問日志 -->
    <appender name="ACCESS" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${LOG_HOME}/access.log</file>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%X{requestId}] %msg%n</pattern>
        </encoder>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_HOME}/access.%d{yyyy-MM-dd}.log</fileNamePattern>
            <maxHistory>30</maxHistory>
        </rollingPolicy>
    </appender>
    <!-- 錯(cuò)誤日志 -->
    <appender name="ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${LOG_HOME}/error.log</file>
        <encoder>
            <pattern>${COMMON_PATTERN}</pattern>
        </encoder>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <fileNamePattern>${LOG_HOME}/error.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
            <maxFileSize>100MB</maxFileSize>
            <maxHistory>60</maxHistory>
        </rollingPolicy>
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>ERROR</level>
        </filter>
    </appender>
    <!-- 異步Appender -->
    <appender name="ASYNC_ERROR" class="ch.qos.logback.classic.AsyncAppender">
        <queueSize>1024</queueSize>
        <appender-ref ref="ERROR" />
    </appender>
    <!-- 日志級(jí)別配置 -->
    <root level="INFO">
        <appender-ref ref="CONSOLE" />
    </root>
    <!-- 訪問日志Logger -->
    <logger name="ACCESS_LOG" level="INFO" additivity="false">
        <appender-ref ref="ACCESS" />
    </logger>
    <!-- 錯(cuò)誤日志Logger -->
    <logger name="ERROR_LOG" level="ERROR" additivity="false">
        <appender-ref ref="ASYNC_ERROR" />
    </logger>
    <!-- MyBatis SQL日志 -->
    <logger name="org.mybatis" level="DEBUG" additivity="false">
        <appender-ref ref="SQL" />
    </logger>
</configuration>

6.3 AOP實(shí)現(xiàn)訪問日志

@Aspect
@Component
public class AccessLogAspect {
    private static final Logger accessLog = LoggerFactory.getLogger("ACCESS_LOG");
    @Around("execution(* com.example.ecommerce.controller..*.*(..))")
    public Object logAccess(ProceedingJoinPoint joinPoint) throws Throwable {
        HttpServletRequest request = 
            ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
        // 記錄請(qǐng)求信息
        String requestId = UUID.randomUUID().toString();
        MDC.put("requestId", requestId);
        long start = System.currentTimeMillis();
        try {
            Object result = joinPoint.proceed();
            long cost = System.currentTimeMillis() - start;
            accessLog.info("method={} uri={} status=success cost={}ms ip={} params={}",
                         request.getMethod(),
                         request.getRequestURI(),
                         cost,
                         request.getRemoteAddr(),
                         request.getQueryString());
            return result;
        } catch (Exception e) {
            long cost = System.currentTimeMillis() - start;
            accessLog.error("method={} uri={} status=error cost={}ms error={}",
                          request.getMethod(),
                          request.getRequestURI(),
                          cost,
                          e.getMessage());
            throw e;
        } finally {
            MDC.clear();
        }
    }
}

七、總結(jié)

7.1 關(guān)鍵要點(diǎn)總結(jié)

  • 統(tǒng)一使用SLF4j API:保持代碼與具體實(shí)現(xiàn)解耦
  • 合理配置日志級(jí)別:生產(chǎn)環(huán)境通常INFO,開發(fā)環(huán)境DEBUG
  • 日志文件分割策略:按時(shí)間和大小雙維度分割
  • 使用MDC增強(qiáng)日志:添加請(qǐng)求跟蹤信息
  • 性能優(yōu)化:異步日志、參數(shù)化日志、isXXXEnabled判斷
  • 多環(huán)境支持:利用Profile實(shí)現(xiàn)差異化配置

到此這篇關(guān)于Spring Boot集成SLF4j從基礎(chǔ)到高級(jí)實(shí)踐(最新推薦)的文章就介紹到這了,更多相關(guān)Spring Boot集成SLF4j內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Springboot添加jvm監(jiān)控實(shí)現(xiàn)數(shù)據(jù)可視化

    Springboot添加jvm監(jiān)控實(shí)現(xiàn)數(shù)據(jù)可視化

    這篇文章主要介紹了Springboot添加jvm監(jiān)控實(shí)現(xiàn)數(shù)據(jù)可視化,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • 使用Java 8 Lambda表達(dá)式將實(shí)體映射到DTO的操作

    使用Java 8 Lambda表達(dá)式將實(shí)體映射到DTO的操作

    這篇文章主要介紹了使用Java 8 Lambda表達(dá)式將實(shí)體映射到DTO的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • MybatisPlus中的多表?xiàng)l件排序查詢

    MybatisPlus中的多表?xiàng)l件排序查詢

    這篇文章主要介紹了MybatisPlus中的多表?xiàng)l件排序查詢,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Spring Boot 3.x 集成 Eureka Server/Client的詳細(xì)過程

    Spring Boot 3.x 集成 Eureka Server/Cl

    隨著SpringBoot 3.x版本的開發(fā)嘗試,本文記錄了在集成Eureka Server/Client時(shí)所遇到的問題和解決方案,文中詳細(xì)介紹了搭建服務(wù)、配置文件和測(cè)試步驟,感興趣的朋友跟隨小編一起看看吧
    2024-09-09
  • java隨機(jī)事件分發(fā)器示例

    java隨機(jī)事件分發(fā)器示例

    這篇文章主要介紹了java隨機(jī)事件分發(fā)器示例,需要的朋友可以參考下,功能需求和代碼實(shí)現(xiàn)在下面
    2014-03-03
  • 十分鐘理解Java中的動(dòng)態(tài)代理

    十分鐘理解Java中的動(dòng)態(tài)代理

    十分鐘幫助大家理解Java中的動(dòng)態(tài)代理,什么是動(dòng)態(tài)代理?感興趣的小伙伴們可以參考一下
    2016-06-06
  • 現(xiàn)代高效的java構(gòu)建工具gradle的快速入門

    現(xiàn)代高效的java構(gòu)建工具gradle的快速入門

    和Maven一樣,Gradle只是提供了構(gòu)建項(xiàng)目的一個(gè)框架,真正起作用的是Plugin,本文主要介紹了gradle入門,文中通過示例代碼介紹的非常詳細(xì),感興趣的小伙伴們可以參考一下
    2021-11-11
  • java前后端加密解密crypto-js的實(shí)現(xiàn)

    java前后端加密解密crypto-js的實(shí)現(xiàn)

    這篇文章主要介紹了java前后端加密解密crypto-js的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • 教你1秒將本地SpringBoot項(xiàng)目jar包部署到Linux環(huán)境(超詳細(xì)!)

    教你1秒將本地SpringBoot項(xiàng)目jar包部署到Linux環(huán)境(超詳細(xì)!)

    spring Boot簡化了Spring應(yīng)用的開發(fā)過程,遵循約定優(yōu)先配置的原則提供了各類開箱即用(out-of-the-box)的框架配置,下面這篇文章主要給大家介紹了關(guān)于1秒將本地SpringBoot項(xiàng)目jar包部署到Linux環(huán)境的相關(guān)資料,超級(jí)詳細(xì),需要的朋友可以參考下
    2023-04-04
  • 快速定位Java 內(nèi)存OOM的問題

    快速定位Java 內(nèi)存OOM的問題

    這篇文章主要介紹了快速定位Java 內(nèi)存OOM的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03

最新評(píng)論