浅谈Java slf4j日志简单理解

作者:Developer 时间:2021-07-07 15:49:15 

一、理解

slf4j(Simple Logging Facade for Java),表示为java提供的简单日志门面,更底层一点说就是接口。通过将程序中的信息导入到日志系统并记录,实现程序和日志系统的解耦

日志门面接口本身通常并没有实际的日志输出能力,它底层还是需要去调用具体的日志框架API的,也就是实际上它需要跟具体的日志框架结合使用。由于具体日志框架比较多,而且互相也大都不兼容,日志门面接口要想实现与任意日志框架结合可能需要对应的桥接器,就好像JDBC与各种不同的数据库之间的结合需要对应的JDBC驱动一样。

1. 日志门面(Facade)

1.slf4j(推荐)
2.commons-logging

2. slf4j连接具体的日志

slf4j和其它日志框架连接的时候,中间需要一个桥接器。有的日志框架本身就使用了slf4j的api,则不需要使用桥接器.

logback是log4j的改良版,且内部直接使用了slf4j的api,所以不用桥接器。(logback和slf4j据说是出自同一个作者)
1.slf4j-api.jar > slf4j-log4j12.jar桥接器 > log4j.jar
2.slf4j-api.jar > logback-core.jar,logback-classic.jar
3.slf4j-api.jar > slf4j-simple.jar
4.slf4j-api.jar > log4j-slf4j-impl-2.8.2.jar > org.apache.logging.log4j:log4j-api:2.8.2,org.apache.logging.log4j:log4j-core:2.8.2,org.apache.logging.log4j:log4j-web:2.8.2 (推荐使用 log4j2)

二、使用 slf4j+log4j2

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="info">
     <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");
 }

}

参考文章:https://www.jb51.net/article/143486.htm

来源:https://segmentfault.com/a/1190000015568427

标签:Java,日志
0
投稿

猜你喜欢

  • Spring项目中使用Junit单元测试并配置数据源的操作

    2022-06-02 05:32:27
  • Java实现简易Web服务器

    2023-11-17 09:10:11
  • 使用Java操作TensorFlow的方法

    2023-11-27 21:31:38
  • SpringBoot框架中Mybatis-plus的简单使用操作汇总

    2022-12-17 19:10:53
  • Java 代理(Proxy)的原理及应用

    2023-08-21 08:40:41
  • log4j2日志异步打印(实例讲解)

    2023-11-12 09:02:13
  • Java中后台线程实例解析

    2022-01-05 06:45:08
  • Java Base64解码错误及解决方法

    2023-02-09 03:36:35
  • Android 实现签到足迹功能

    2023-06-21 15:16:24
  • MyBatis动态SQL标签用法实例详解

    2023-11-26 01:04:27
  • MyBatis通过JDBC数据驱动生成的执行语句问题

    2023-08-24 08:42:18
  • Zookeeper事务日志预分配空间解读

    2022-03-16 22:36:49
  • 常用json与javabean互转的方法实现

    2023-01-07 14:24:19
  • 详解Spring的StringUtils踩坑记录

    2021-08-23 16:14:39
  • Android集成Flutter

    2023-07-06 13:07:33
  • 基于Java8实现提高Excel读写效率

    2023-11-25 10:01:37
  • Struts中使用validate()输入校验方法详解

    2023-03-02 19:10:41
  • JAVA基于数组实现的商品信息查询功能示例

    2021-10-31 11:47:23
  • bool当成函数参数错误理解

    2021-07-30 09:27:18
  • 深入学习Java编程中的字符串的进阶使用

    2023-11-11 12:54:20
  • asp之家 软件编程 m.aspxhome.com