목차
개요
Spring Boot Logging 플러그인을 사용하세요
集成Log4J日志框架
Controller code
Postscript
백엔드 개발 PHP 튜토리얼 Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

May 05, 2018 pm 03:11 PM
boot spring 관행

이 글은 주로 Spring Boot 로깅 프레임워크의 실습을 공유합니다. 코드 부분도 매우 자세하게 설명되어 있어 도움이 필요한 친구들이 참고할 수 있습니다.


개요

Java 애플리케이션에서 로그는 일반적으로 다음 5개 수준으로 나뉩니다.

  • ERROR 오류 메시지

  • WARN 경고 메시지

  • INFO 일반 정보

  • DEBUG 디버그 정보

  • TRACE 추적 정보

Spring Boot는 Apache의 Commons Logging을 내부 로깅 프레임워크로 사용합니다. 이는 단지 로그 인터페이스일 뿐이며, 이 인터페이스에 해당하는 로그 구현을 지정해야 합니다.

SpringBt의 기본 로깅 구현은 JDK와 함께 제공되는 로깅 패키지인 Java Util Logging입니다. 또한 SpringBt는 물론 Log4J 및 Logback과 같은 널리 사용되는 로깅 구현도 지원합니다.

위의 로그 구현을 통칭하여 로그 프레임워크

라고 부릅니다. 지금 연습해 보세요!


Spring Boot Logging 플러그인을 사용하세요

  • 먼저 application.properties 파일에 구성을 추가하세요:

logging.level.root=INFO
로그인 후 복사
  • 컨트롤러 부분 코드는 다음과 같습니다:

package com.hansonwang99.controller;

import com.hansonwang99.K8sresctrlApplication;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/testlogging")
public class LoggingTestController {
    private static Logger logger = LoggerFactory.getLogger(K8sresctrlApplication.class);
    @GetMapping("/hello")
    public String hello() {
        logger.info("test logging...");
        return "hello";
    }
}
로그인 후 복사
  • 실행 결과

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

로그 수준이 INFO로 설정되어 있으므로 INFO 이상의 수준을 포함하는 로그 정보가 인쇄됩니다.

여기서 볼 수 있듯이 대부분의 INFO 로그는 SpringBt 프레임워크 자체에서 생성됩니다. 이를 차단하려면 먼저 모든 로그 수준을 ERROR로 설정하여 프레임워크 자체 INFO 정보가 인쇄되지 않도록 할 수 있습니다. 그런 다음 애플리케이션의 특정 패키지를 DEBUG 수준 로그로 설정하면 관심 있는 패키지에서 DEBUG 및 상위 수준 로그만 볼 수 있습니다.

  • 특정 패키지의 로그 수준 제어

application.yml에서 구성을 변경하세요

logging:
  level:
    root: error
    com.hansonwang99.controller: debug
로그인 후 복사

분명히 루트 로그 수준을 ERROR로 설정한 다음 com.hansonwang99.controller</를 추가하세요. code> 패키지 로그 수준이 DEBUG로 설정됩니다. 즉, 먼저 모두 금지하고 개별 설정 방법을 허용합니다<code>com.hansonwang99.controller包的日志级别设为DEBUG,此即:即先禁止所有再允许个别的 设置方法

  • 控制器代码

package com.hansonwang99.controller;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/testlogging")
public class LoggingTestController {
    private Logger logger = LoggerFactory.getLogger(this.getClass());
    @GetMapping("/hello")
    public String hello() {
        logger.info("test logging...");
        return "hello";
    }
}
로그인 후 복사
  • 运行结果

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

可见框架自身的INFO级别日志全部藏匿,而指定包中的日志按级别顺利地打印出来

  • 将日志输出到某个文件中

logging:
  level:
    root: error
    com.hansonwang99.controller: debug
  file: ${user.home}/logs/hello.log
로그인 후 복사
  • 运行结果

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

使用Spring Boot Logging,我们发现虽然日志已输出到文件中,但控制台中依然会打印一份,发现用org.slf4j.Logger是无法解决这个问题的

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유


集成Log4J日志框架

  • pom.xml中添加依赖

       <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>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-log4j2</artifactId>
        </dependency>
로그인 후 복사
  • 在resources目录下添加log4j2.xml文件,内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>

    <appenders>
        <File name="file" fileName="${sys:user.home}/logs/hello2.log">
            <PatternLayout pattern="%d{HH:mm:ss,SSS} %p %c (%L) - %m%n"/>
        </File>
    </appenders>

    <loggers>

        <root level="ERROR">
            <appender-ref ref="file"/>
        </root>
        <logger name="com.hansonwang99.controller" level="DEBUG" />
    </loggers>

</configuration>
로그인 후 복사
  • 其他代码都保持不变

运行程序发现控制台没有日志输出,而hello2.log文件中有内容,这符合我们的预期:

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

而且日志格式和pattern="%d{HH:mm:ss,SSS} %p %c (%L) - %m%n"


Controller code

  •         <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>
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-log4j2</artifactId>
            </dependency>
    로그인 후 복사

  • Run results
  • Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유
    프레임워크 자체의 INFO 레벨 로그는 모두 숨겨져 있는 것을 볼 수 있으며, 로그는 지정된 패키지가 레벨별로 원활하게 출력됩니다
  • 로그를 파일로 출력
  • <?xml version="1.0" encoding="UTF-8"?>
    <configuration status="warn">
        <properties>
    
            <Property name="app_name">springboot-web</Property>
            <Property name="log_path">logs/${app_name}</Property>
    
        </properties>
        <appenders>
            <console name="Console" target="SYSTEM_OUT">
                <PatternLayout pattern="[%d][%t][%p][%l] %m%n" />
            </console>
    
            <RollingFile name="RollingFileInfo" fileName="${log_path}/info.log"
                         filePattern="${log_path}/$${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log.gz">
                <Filters>
                    <ThresholdFilter level="INFO" />
                    <ThresholdFilter level="WARN" onMatch="DENY"
                                     onMismatch="NEUTRAL" />
                </Filters>
                <PatternLayout pattern="[%d][%t][%p][%c:%L] %m%n" />
                <Policies>
                    <!-- 归档每天的文件 -->
                    <TimeBasedTriggeringPolicy interval="1" modulate="true" />
                    <!-- 限制单个文件大小 -->
                    <SizeBasedTriggeringPolicy size="2 MB" />
                </Policies>
                <!-- 限制每天文件个数 -->
                <DefaultRolloverStrategy compressionLevel="0" max="10"/>
            </RollingFile>
    
            <RollingFile name="RollingFileWarn" fileName="${log_path}/warn.log"
                         filePattern="${log_path}/$${date:yyyy-MM}/warn-%d{yyyy-MM-dd}-%i.log.gz">
                <Filters>
                    <ThresholdFilter level="WARN" />
                    <ThresholdFilter level="ERROR" onMatch="DENY"
                                     onMismatch="NEUTRAL" />
                </Filters>
                <PatternLayout pattern="[%d][%t][%p][%c:%L] %m%n" />
                <Policies>
                    <!-- 归档每天的文件 -->
                    <TimeBasedTriggeringPolicy interval="1" modulate="true" />
                    <!-- 限制单个文件大小 -->
                    <SizeBasedTriggeringPolicy size="2 MB" />
                </Policies>
                <!-- 限制每天文件个数 -->
                <DefaultRolloverStrategy compressionLevel="0" max="10"/>
            </RollingFile>
    
            <RollingFile name="RollingFileError" fileName="${log_path}/error.log"
                         filePattern="${log_path}/$${date:yyyy-MM}/error-%d{yyyy-MM-dd}-%i.log.gz">
                <ThresholdFilter level="ERROR" />
                <PatternLayout pattern="[%d][%t][%p][%c:%L] %m%n" />
                <Policies>
                    <!-- 归档每天的文件 -->
                    <TimeBasedTriggeringPolicy interval="1" modulate="true" />
                    <!-- 限制单个文件大小 -->
                    <SizeBasedTriggeringPolicy size="2 MB" />
                </Policies>
                <!-- 限制每天文件个数 -->
                <DefaultRolloverStrategy compressionLevel="0" max="10"/>
            </RollingFile>
    
        </appenders>
    
        <loggers>
    
    
            <root level="info">
                <appender-ref ref="Console" />
                <appender-ref ref="RollingFileInfo" />
                <appender-ref ref="RollingFileWarn" />
                <appender-ref ref="RollingFileError" />
            </root>
    
        </loggers>
    
    </configuration>
    로그인 후 복사

  • 실행 결과

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

🎜Spring Boot Logging을 사용하여 로그가 파일로 출력되었지만 콘솔에는 여전히 복사본이 인쇄된다는 것을 발견했습니다. org.slf4j.Logger를 사용하여 발견했습니다. 이 문제를 해결할 수 없습니다🎜🎜🎜Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유🎜🎜🎜🎜Log4J 로깅 프레임워크 통합🎜🎜 🎜🎜pom.xml🎜🎜🎜
package com.hansonwang99.controller;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/testlogging")
public class LoggingTestController {
    private final Logger logger = LogManager.getLogger(this.getClass());
    @GetMapping("/hello")
    public String hello() {
        for(int i=0;i<10_0000;i++){
            logger.info("info execute index method");
            logger.warn("warn execute index method");
            logger.error("error execute index method");
        }
        return "My First SpringBoot Application";
    }
}
로그인 후 복사
에 종속성을 추가합니다. 🎜🎜🎜다음 내용으로 리소스 디렉터리에 log4j2.xml 파일을 추가합니다. 🎜🎜🎜rrreee🎜🎜🎜다른 코드는 변경되지 않습니다.🎜 🎜🎜🎜프로그램을 실행하고 콘솔에 로그 출력이 없음을 확인하세요. hello2.log 파일에 우리의 기대와 일치하는 콘텐츠가 있습니다: 🎜🎜🎜Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유 🎜🎜🎜🎜Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유🎜🎜🎜🎜Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유🎜🎜🎜 그리고 로그 형식은 pattern="%d{HH:mm:ss,SSS} %p %c (%L)입니다 - %m%n" 형식에 정의된 것과 일치합니다 🎜🎜🎜Log4J 추가 연습 🎜🎜🎜🎜pom.xml 구성: 🎜🎜🎜rrreee🎜🎜🎜log4j2.xml 구성🎜 🎜🎜rrreee🎜🎜🎜컨트롤러 코드: 🎜🎜🎜rrreee🎜🎜🎜실행 결과 🎜🎜🎜🎜🎜🎜🎜🎜🎜 🎜🎜🎜🎜

Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유

로그는 레벨에 따라 다른 파일로 저장됩니다. 로그 파일 크기가 2M를 초과하면 압축 저장을 위해 여러 파일로 분할됩니다. 프로덕션 환경에서는 로그 파일 크기를 권장합니다. 20~50MB로 조정되었습니다.


Postscript

저자의 더 많은 원본 기사를 보려면 SF 칼럼을 참조하세요.

저자의 더 많은 SpringBt 실습 기사는 여기에 있습니다:

  • SpringBoot의 ElasticSearch 검색 엔진 실습

  • Kotlin+SpringBoot의 예비 탐색 공동 프로그래밍



관련 권장 사항:

Java 프로그래머가 가장 일반적으로 사용하는 8가지 Java 로깅 프레임워크

위 내용은 Spring Boot 로깅 프레임워크 실습 - hansonwang99 님의 기술 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Windows ISO 파일이 너무 큼 BootCamp 오류 [수정됨] Windows ISO 파일이 너무 큼 BootCamp 오류 [수정됨] Feb 19, 2024 pm 12:30 PM

Mac 컴퓨터에서 BootCampAssistant를 사용할 때 "Windows ISO 파일이 너무 큽니다"라는 오류 메시지가 표시되는 경우 ISO 파일 크기가 BootCampAssistant에서 지원하는 제한을 초과했기 때문일 수 있습니다. 이 문제에 대한 해결책은 다른 도구를 사용하여 ISO 파일 크기를 압축하여 BootCamp Assistant에서 처리할 수 있도록 하는 것입니다. BootCampAssistant는 Mac 컴퓨터에 Windows 운영 체제를 설치하고 실행하기 위해 Apple에서 제공하는 편리한 도구입니다. 사용자가 듀얼 부팅 시스템을 설정하여 시작 시 MacOS 또는 Wind를 사용하도록 쉽게 선택할 수 있습니다.

Spring Boot가 OpenAI를 만났을 때 새로운 프로그래밍 패러다임 Spring Boot가 OpenAI를 만났을 때 새로운 프로그래밍 패러다임 Feb 01, 2024 pm 09:18 PM

2023년에는 AI 기술이 화두가 되면서 다양한 산업, 특히 프로그래밍 분야에 큰 영향을 미치고 있다. 사람들은 AI 기술의 중요성을 점점 더 인식하고 있으며 Spring 커뮤니티도 예외는 아닙니다. GenAI(일반 인공 지능) 기술이 지속적으로 발전함에 따라 AI 기능을 갖춘 애플리케이션 생성을 단순화하는 것이 중요하고 시급해졌습니다. 이러한 배경에서 AI 기능 애플리케이션 개발 프로세스를 단순화하고 간단하고 직관적이며 불필요한 복잡성을 피하는 것을 목표로 하는 "SpringAI"가 등장했습니다. 'SpringAI'를 통해 개발자는 AI 기능이 포함된 애플리케이션을 더욱 쉽게 구축할 수 있어 사용 및 운영이 더욱 쉬워진다.

Spring Boot 및 Spring AI를 사용하여 생성 인공 지능 애플리케이션 구축 Spring Boot 및 Spring AI를 사용하여 생성 인공 지능 애플리케이션 구축 Apr 28, 2024 am 11:46 AM

업계 리더인 Spring+AI는 강력하고 유연한 API와 고급 기능을 통해 다양한 산업에 선도적인 솔루션을 제공합니다. 이 주제에서는 다양한 분야의 Spring+AI 적용 사례를 살펴보겠습니다. 각 사례에서는 Spring+AI가 어떻게 특정 요구 사항을 충족하고 목표를 달성하며 이러한 LESSONSLEARNED를 더 넓은 범위의 애플리케이션으로 확장하는지 보여줍니다. 이 주제가 여러분이 Spring+AI의 무한한 가능성을 더 깊이 이해하고 활용하는 데 영감을 줄 수 있기를 바랍니다. Spring 프레임워크는 소프트웨어 개발 분야에서 20년 이상의 역사를 가지고 있으며, Spring Boot 1.0 버전이 출시된 지 10년이 되었습니다. 이제 봄이 왔다는 것에 대해 누구도 이의를 제기할 수 없습니다.

Spring 프로그래밍 방식 트랜잭션의 구현 방법은 무엇입니까? Spring 프로그래밍 방식 트랜잭션의 구현 방법은 무엇입니까? Jan 08, 2024 am 10:23 AM

Spring 프로그래밍 방식 트랜잭션을 구현하는 방법: 1. TransactionCallback 및 TransactionCallbackWithoutResult를 사용합니다. 3. Transactional 주석을 사용합니다. 4. @Transactional과 함께 TransactionTemplate을 사용합니다.

Outlook이 내 일정에 이벤트를 자동으로 추가하는 것을 중지하는 방법 Outlook이 내 일정에 이벤트를 자동으로 추가하는 것을 중지하는 방법 Feb 26, 2024 am 09:49 AM

이메일 관리자 애플리케이션인 Microsoft Outlook을 사용하면 이벤트와 약속을 예약할 수 있습니다. 이를 통해 Outlook 응용 프로그램에서 이러한 활동(이벤트라고도 함)을 생성, 관리 및 추적할 수 있는 도구를 제공하여 체계적으로 정리할 수 있습니다. 그러나 때로는 원치 않는 이벤트가 Outlook의 일정에 추가되어 사용자에게 혼란을 주고 일정에 스팸을 보내는 경우가 있습니다. 이 문서에서는 Outlook이 내 일정에 이벤트를 자동으로 추가하지 못하도록 방지하는 데 도움이 되는 다양한 시나리오와 단계를 살펴보겠습니다. Outlook 이벤트 – 간략한 개요 Outlook 이벤트는 다양한 용도로 사용되며 다음과 같은 유용한 기능을 많이 가지고 있습니다. 일정 통합: Outlook에서

Spring에서 트랜잭션 격리 수준을 설정하는 방법 Spring에서 트랜잭션 격리 수준을 설정하는 방법 Jan 26, 2024 pm 05:38 PM

Spring에서 트랜잭션 격리 수준을 설정하는 방법: 1. @Transactional 주석을 사용합니다. 2. Spring 구성 파일에서 설정합니다. 3. PlatformTransactionManager를 사용합니다. 4. Java 구성 클래스에서 설정합니다. 자세한 소개: 1. @Transactional 주석을 사용하고, 트랜잭션 관리가 필요한 클래스나 메소드에 @Transactional 주석을 추가하고, 속성에서 격리 수준을 설정합니다. 2. Spring 구성 파일에서 등.

Dreamweaver CMS 스테이션 그룹 실습 공유 Dreamweaver CMS 스테이션 그룹 실습 공유 Mar 18, 2024 am 10:18 AM

Dreamweaver CMS 스테이션 그룹 실습 공유 최근 몇 년간 인터넷의 급속한 발전으로 인해 웹사이트 구축이 점점 더 중요해지고 있습니다. 여러 웹사이트를 구축할 때 사이트 그룹 기술은 매우 효과적인 방법이 되었습니다. 많은 웹 사이트 구축 도구 중에서 DreamWeaver CMS는 유연성과 사용 용이성으로 인해 많은 웹 사이트 애호가들의 첫 번째 선택이 되었습니다. 이 기사에서는 Dreamweaver CMS 스테이션 그룹에 대한 몇 가지 실제 경험과 일부 특정 코드 예제를 공유하여 스테이션 그룹 기술을 탐색하는 독자에게 도움이 되기를 바랍니다. 1. Dreamweaver CMS 스테이션 그룹이란 무엇입니까? 드림위버 CMS

Struts 프레임워크의 원칙과 실무에 대한 심층적인 토론 Struts 프레임워크의 원칙과 실무에 대한 심층적인 토론 Feb 18, 2024 pm 06:10 PM

Struts 프레임워크의 원리 분석 및 실제 탐색 JavaWeb 개발에서 일반적으로 사용되는 MVC 프레임워크인 Struts 프레임워크는 우수한 디자인 패턴과 확장성을 가지며 엔터프라이즈 수준 애플리케이션 개발에 널리 사용됩니다. 이 기사에서는 Struts 프레임워크의 원리를 분석하고 실제 코드 예제를 통해 이를 탐색하여 독자가 프레임워크를 더 잘 이해하고 적용할 수 있도록 돕습니다. 1. Struts 프레임워크의 원리 분석 1. MVC 아키텍처 Struts 프레임워크는 MVC(Model-View-Con)를 기반으로 합니다.

See all articles