Java中怎么操作slf4j日志

这篇文章将为大家详细讲解有关Java中怎么操作slf4j日志,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

一、理解

Java中怎么操作slf4j日志

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.jar2.slf4j-api.jar > logback-core.jar,logback-classic.jar3.slf4j-api.jar > slf4j-simple.jar4.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目录下

<?xmlversion="1.0"encoding="UTF-8"?>
<!--
6个优先级从高到低依次为:OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE、ALL。
如果设置优先级为WARN,那么OFF、FATAL、ERROR、WARN4个级别的log能正常输出
设置为OFF表示不记录log4j2本身的日志,
-->

<!--status:用来指定log4j本身的打印日志级别,monitorInterval:指定log4j自动重新配置的监测间隔时间-->
<configurationstatus="INFO"monitorInterval="30">
<!--自己设置属性,后面通过${}来访问-->
<properties>
<propertyname="LOG_HOME">${web:rootDir}/logs</property>
</properties>
<appenders>
<!--Appender1.输出到Console控制台,指定输出格式和过滤器等级为INFO-->
<Consolename="Console"target="SYSTEM_OUT">
<!--ThresholdFilter指定日志消息的输出最低层次-->
<ThresholdFilterlevel="ALL"onMatch="ACCEPT"onMismatch="DENY"/>
<PatternLayoutpattern="%d{HH:mm:ss.SSS}%-5level%class{36}%L%M-%msg%xEx%n"/>
</Console>

<!--Appender2.输出到滚动保存的文件,触发保存日志文件的条件是日志文件大于3KB,只保存最新的10个日志-->
<Filename="allLog"fileName="${LOG_HOME}/all.log">
<ThresholdFilterlevel="ALL"onMatch="ACCEPT"onMismatch="DENY"/>
<PatternLayoutcharset="UTF-8"pattern="%d{yyyy.MM.dd'at'HH:mm:ssz}%-5level%class{36}%L%M-%msg%xEx%n"/>
</File>


<!--Appender3.输出到滚动保存的文件,触发保存日志文件的条件是日志文件大于3KB,只保存最新的10个日志-->
<RollingFilename="debugLog"fileName="${LOG_HOME}/debug.log"filePattern="${log.path}/debug-%i.log">
<ThresholdFilterlevel="DEBUG"onMatch="ACCEPT"onMismatch="DENY"/>
<PatternLayoutcharset="UTF-8"pattern="[%-5level][%d{yyyy-MM-ddHH:mm:ss}][%F:%L]-%m%n"/>
<SizeBasedTriggeringPolicysize="3KB"/>
<!--DefaultRolloverStrategy中的参数max,可以限制SizeBasedTriggeringPolicy中size超出后,只保留max个存档-->
<DefaultRolloverStrategymax="10"/>
</RollingFile>

<!--Appender4.输出到滚动保存的文件,触发保存日志文件的条件是每分钟第一次的日志事件。ERROR日志是按分钟产生日志-->
<RollingFilename="errorLog"fileName="${LOG_HOME}/error.log"
filePattern="${log.path}/error-%d{yyyy-MM-dd_HH-mm}.log">
<ThresholdFilterlevel="ERROR"onMatch="ACCEPT"onMismatch="DENY"/>
<PatternLayoutcharset="UTF-8"pattern="[%-5level][%d{yyyy-MM-ddHH:mm:ss}][%C:%F:%L]-%m%n"/>
<TimeBasedTriggeringPolicy/>
</RollingFile>

<RollingFilename="RollingFile"fileName="${LOG_HOME}/rar.log"
filePattern="${LOG_HOME}/$${date:yyyy-MM}/${FILE_NAME}-%d{MM-dd-yyyy}-%i.log.gz">
<PatternLayoutcharset="UTF-8"pattern="%d{yyyy-MM-dd'at'HH:mm:ssz}%-5level%class{36}%L%M-%msg%xEx%n"/>
<!--日志文件最大值第二天压缩-->
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicysize="10MB"/>
</Policies>
</RollingFile>


</appenders>
<!--root默认加载-->
<loggers>
<rootlevel="info">
<appender-refref="Console"/>
<!--<appender-refref="allLog"/>-->
<!--<appender-refref="debugLog"/>-->
<appender-refref="errorLog"/>
<!--<appender-refref="RollingFile"/>-->
</root>
</loggers>
</configuration>

LogTest.java

importorg.slf4j.Logger;
importorg.slf4j.LoggerFactory;

publicclassLogTest{
publicfinalLoggerlogger=LoggerFactory.getLogger(getClass());

publicstaticvoidmain(String[]args){
log.trace("trace");
log.debug("debug");
log.warn("warn");
log.info("info");
log.error("error");
}

}

关于Java中怎么操作slf4j日志就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

发布于 2021-06-13 23:18:15
收藏
分享
海报
0 条评论
170
上一篇:PHPUnit中使用 Laravel怎么实现单元测试 下一篇:怎么做好软件测试工作
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码