百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

springBoot使用Log4j

yuyutoo 2025-01-09 17:07 2 浏览 0 评论


添加依赖

   <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-log4j2</artifactId>
    </dependency>

log4j2.xml 配置

<?xml version="1.0" encoding="UTF-8"?>
<!--设置log4j2的自身log级别为warn-->
<!--日志级别以及优先级排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL -->
<!--Configuration后面的status,这个用于设置log4j2自身内部的信息输出,可以不设置,
    当设置成trace时,你会看到log4j2内部各种详细输出-->
<!--monitorInterval:Log4j能够自动检测修改配置 文件和重新配置本身,设置间隔秒数-->
<Configuration status="TRACE">
    <Properties>
        <Property name="LOG_ROOT" value="${sys:ljm.log.path:-logs}"></Property>
        <Property name="BACKUP_FOLDER">${LOG_ROOT}/bak</Property>
<!--        %-5level 输出日志级别,-5表示左对齐并且固定输出5个字符,如果不足在右边补0-->
        <Property name="logFormat">%d{yyyy-MM-dd HH:mm:ss},%L  %t %p %C{1.} --->> %9m%n</Property>
        <Property name="errFormat">%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %C - %m%n %ex%n</Property>
    </Properties>
    <!--先定义所有的appender-->
    <Appenders>
        <!--这个输出控制台的配置-->
        <Console name="Console" target="SYSTEM_OUT">
            <!--输出日志的格式-->
            <PatternLayout pattern="${logFormat}"/>
        </Console>
<!--关键点在于 filePattern后的日期格式,以及TimeBasedTriggeringPolicy的interval,日期格式精确到哪一位,interval也精确到哪一个单位-->
        <RollingFile name="errorLog" fileName="${LOG_ROOT}/error.log" immediateFlush = "true">
            <FilePattern>${BACKUP_FOLDER}/error.log.%d{yyyy-MM-dd}.gz</FilePattern>
            <PatternLayout pattern="${errFormat}"/>
            <Policies>
                <TimeBasedTriggeringPolicy interval="1" modulate="true" />
            </Policies>
        </RollingFile>
        <RollingFile name="infoLog" fileName="${LOG_ROOT}/info.log" immediateFlush = "true">
            <FilePattern>${BACKUP_FOLDER}/info.log.%d{yyyy-MM-dd}.gz</FilePattern>
            <PatternLayout pattern="${logFormat}"/>
            <Policies>
                <TimeBasedTriggeringPolicy interval="1" modulate="true" />
            </Policies>
        </RollingFile>
        <RollingFile name="debugLog" fileName="${LOG_ROOT}/debug.log" >
            <FilePattern>${BACKUP_FOLDER}/debug.log.%d{yyyy-MM-dd}.gz</FilePattern>
            <PatternLayout pattern="${logFormat}"/>
            <Policies>
                <TimeBasedTriggeringPolicy interval="1" modulate="true" />
            </Policies>
        </RollingFile>
    </Appenders>
    <Loggers>
<!-- 默认情况下子Logger会继承父Logger的appender,也就是说子Logger会在父Logger的appender里输出,并且日志级别高于info的也会打印出来。-->
        <logger name="errorLogger" level="error" additivity="false">
            <AppenderRef ref="errorLog"/>
            <AppenderRef ref="Console"/>
        </logger>
        <logger name="infoLogger" level="info" additivity="false">
            <AppenderRef ref="infoLog"/>
            <AppenderRef ref="Console"/>
        </logger>
        <logger name="debugLogger" level="debug" additivity="false">
            <AppenderRef ref="debugLog"/>
            <AppenderRef ref="Console"/>
        </logger>
<!--        root相当于logger的父级,Logger会在父Logger的appender里输出-->
        <Root level="info">
            <AppenderRef ref="respLog"/>
            <AppenderRef ref="Console"/>
        </Root>
    </Loggers>
</Configuration>

执行:

Logger errorLog = LogManager.getLogger("errorLogger"); 
Logger infoLog = LogManager.getLogger("infoLogger"); 
Logger debugLog = LogManager.getLogger("debugLogger"); 
errorLog.error("error");
infoLog.info("info");
debugLog.debug("debug");


输出:

2020-07-19 11:35:33,19 main ERROR c.l.s.App --->> error 
2020-07-19 11:35:33,20 main INFO c.l.s.App --->> info 
2020-07-19 11:35:33,21 main DEBUG c.l.s.App --->> debug


相关推荐

springBoot使用Log4j

添加依赖<dependency><groupId>org.springframework.boot</groupId><ar...

Log4j 严重漏洞修最新修复方案参考

CVE-2021-44228,原理上是log4j-core代码中的JNDI注入漏洞。这个漏洞可以直接导致服务器被入侵,而且由于“日志”场景的特性,攻击数据可以多层传导,甚至可以威胁到纯内网的服...

如何在Spring Boot中使用Log4j日志框架

SpringBoot是目前Java领域比较流行的一个应用程序开发框架,默认情况下使用的是SLF4J和Logback作为日志框架,但是在某些场景下,我们可能需要用到Log4j或Log4j2来满足一些特...

log4j的使用

初识log4jlog4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIXSyslog...

log4j的详细配置

###设置日志级别###log4j.rootLogger=error,stdout,D,E###输出到控制台###log4j.appender.stdout=org.apac...

深蹲时脚掌的打开弧度到底多少比较合适?

引子哈喽,大家晚上好,今天我还是给大家带来深蹲的小技巧。我们在之前的文章中,已经说过非常多关于深蹲的小技巧了,我想大家也已经知道了该如何去做一个正确的深蹲。今天我要给大家介绍一个经常被大家所忽略的技巧...

中杯vivo X90 对比超大杯X90 Pro+:京东方Q9和三星E6差距大吗?

X90标准版应该是大家目前最早能用到量产天玑9200处理器的一款手机了吧,根据蓝厂准则,想贪便宜肯定不能去线上买呀,线上买只是为了给低预算的朋友“分期”用的,根据线下渠道商提示:X90标准版目前已降价...

学习Geogebra重要的100条学习随笔(12)

角度①“0”:Alt+O;“π”:Alt+P;②GeoGebra默认计算都是使用弧度制;③携带度符号(°)的正常计算,但常量π/180会自动转为弧度。...

高中数学-三角函数

三角函数角的度量单位通常有两种,一种是角度制,另一种就是弧度制。...

数学与三角函数的基础用法和示例(一)

1.ABS函数说明返回数字的绝对值。一个数字的绝对值是该数字不带其符号的形式。语法ABS(number)...

折弯大圆弧每次折多少刀,折弯角度怎么计算

第一种方法如何折圆弧?(无模具时)如上图所示:板厚T=2MM,圆心角为90°1、先计算出弧长:弧长L=90°×3.14÷180°×中心层R59=92.632、选取折弯模具:上模用直剑刀,下模用8V(折...

高中数学里的角,和初中学的不太一样

同学们好,我是李状元数学课的李老师,讲人人都听得懂的高中数学课。经常有同学说起三角函数时会有点头疼,可是呢,三角函数其实是高中数学里比较基础的一部分,虽然应用非常广泛,但是一般都不会考察特别难的题目,...

PS办公技巧:如何更改圆角矩形的弧度?

应用场景下图PS文档中有3个完全相同的圆角矩形(当前所有的圆角半径均为10像素),每个圆角矩形单独占用一个图层。下面我们让第1个图层“圆角矩形上”维持原样不变方便对比观察,将第2个图层“圆角矩形中”的...

解读角度制与弧度制的基础知识(讲义稿)

一、角度制1、什么叫做角度制?我们在平面几何学里研究的角度制,规定周角的1/360度为一度的角。这种用单位来度量角的制度叫做角度制。2、怎样用量角器来测量角?角的大小经常用量角器来测量(1)、点重合,...

高中数学笔记——任意角,弧度制及相关公式

...

取消回复欢迎 发表评论: