您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

SpringBoot怎么集成slf4j和log4j2

2024/6/4 7:27:24发布15次查看
maven依赖
<!--增加log4j2依赖↓--><dependency>  <groupid>org.springframework.boot</groupid>  <artifactid>spring-boot-starter-log4j2</artifactid></dependency><dependency>  <groupid>org.springframework.boot</groupid>  <artifactid>spring-boot-starter-actuator</artifactid>  <exclusions>    <!-- 去除旧log依赖 -->    <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-web</artifactid>  <exclusions>    <!-- 去除旧log依赖 -->    <exclusion>      <groupid>org.springframework.boot</groupid>      <artifactid>spring-boot-starter-logging</artifactid>    </exclusion>  </exclusions></dependency>
如果其它依赖有log日志冲突,可以加入下面配置:
<exclusions>  <exclusion>    <groupid>log4j</groupid>    <artifactid>*</artifactid>  </exclusion>  <exclusion>    <groupid>org.slf4j</groupid>    <artifactid>*</artifactid>  </exclusion>  <exclusion>    <groupid>org.apache.logging.log4j</groupid>    <artifactid>*</artifactid>  </exclusion></exclusions>
log4j2.xml
放在resources目录下
<?xml version="1.0" encoding="utf-8"?><!-- 6个优先级从高到低依次为:off、fatal、error、warn、info、debug、trace、 all。 如果设置优先级为warn,那么off、fatal、error、warn 4个级别的log能正常输出 设置为off 表示不记录log4j2本身的日志, --><!-- status:用来指定log4j本身的打印日志级别,monitorinterval:指定log4j自动重新配置的监测间隔时间 --><configuration status="info" monitorinterval="30">  <!-- 自己设置属性,后面通过${}来访问 --><!-- <properties>    <property name="log_home">${web:rootdir}/logs</property>  </properties>-->  <appenders>    <!--appender 1. 输出到console控制台,指定输出格式和过滤器等级为info -->    <console name="console" target="system_out">      <!--thresholdfilter指定日志消息的输出最低层次-->      <thresholdfilter level="all" onmatch="accept" onmismatch="deny"/>      <patternlayout pattern="%d{hh:mm:ss.sss} %-5level %class{36} %l %m - %msg%xex%n"/>    </console>    <!--appender 2. 输出到滚动保存的文件, 触发保存日志文件的条件是日志文件大于3kb,只保存最新的10个日志-->    <file name="alllog" filename="${log_home}/all.log">      <thresholdfilter level="all" onmatch="accept" onmismatch="deny"/>      <patternlayout charset="utf-8" pattern="%d{yyyy.mm.dd 'at' hh:mm:ss z} %-5level %class{36} %l %m - %msg%xex%n"/>    </file>    <!--appender 3. 输出到滚动保存的文件, 触发保存日志文件的条件是日志文件大于3kb,只保存最新的10个日志-->    <rollingfile name="debuglog" filename="${log_home}/debug.log" filepattern="${log.path}/debug-%i.log">      <thresholdfilter level="debug" onmatch="accept" onmismatch="deny"/>      <patternlayout charset="utf-8" pattern="[%-5level][%d{yyyy-mm-dd hh:mm:ss}][%f:%l] - %m%n"/>      <sizebasedtriggeringpolicy size="3kb"/>      <!-- defaultrolloverstrategy 中的参数max,可以限制 sizebasedtriggeringpolicy中size超出后,只保留max个存档-->      <defaultrolloverstrategy max="10"/>    </rollingfile>    <!--appender 4. 输出到滚动保存的文件, 触发保存日志文件的条件是每分钟第一次的日志事件。error日志是按分钟产生日志 -->    <rollingfile name="errorlog" filename="${log_home}/error.log" filepattern="${log.path}/error-%d{yyyy-mm-dd_hh-mm}.log">      <thresholdfilter level="error" onmatch="accept" onmismatch="deny"/>      <patternlayout charset="utf-8" pattern="[%-5level][%d{yyyy-mm-dd hh:mm:ss}][%c:%f:%l] - %m%n"/>      <timebasedtriggeringpolicy/>    </rollingfile>    <rollingfile name="rollingfile" filename="${log_home}/rar.log" filepattern="${log_home}/$${date:yyyy-mm}/${file_name}-%d{mm-dd-yyyy}-%i.log.gz">      <patternlayout charset="utf-8" pattern="%d{yyyy-mm-dd 'at' hh:mm:ss z} %-5level %class{36} %l %m - %msg%xex%n"/>      <!--日志文件最大值 第二天压缩-->      <policies>        <timebasedtriggeringpolicy/>        <sizebasedtriggeringpolicy size="10 mb"/>      </policies>    </rollingfile>  </appenders>  <!--root 默认加载-->  <loggers>    <root level="debug">      <appender-ref ref="console"/>      <!--<appender-ref ref="alllog"/>-->      <!--<appender-ref ref="debuglog"/>-->      <!--<appender-ref ref="errorlog"/>-->      <!--<appender-ref ref="rollingfile"/>-->    </root>  </loggers></configuration>
logtest.java
import org.slf4j.logger;import org.slf4j.loggerfactory;public class logtest {  public final logger logger=loggerfactory.getlogger(getclass());  public static void main(string[] args) {    log.trace(trace);    log.debug(debug);    log.warn(warn);    log.info(info);    log.error(error);  }}
以上就是springboot怎么集成slf4j和log4j2的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product