版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a940902940902/article/details/79915836
日志配置使用 Slf4j集成 log4j
- 为什么使用slf4j
- slf4j集成log4j所需jar包及maven配置
- slf4j及log4j配置文件
- slf4j集成log4j示例
为什么使用slf4j
SLF4J,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志系统。通过示例说明该特性:
public class App {
final Logger logger = LoggerFactory.getLogger(App.class);
private void test() {
logger.info("这是一条日志信息 - {}", "mafly");
}
public static void main(String[] args) {
App app = new App();
app.test();
System.out.println("Hello World!");
}
}
对于不同的日志系统而言只需增加slf4j依赖包
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.22</version>
</dependency>
对于使用logback日志系统用户而言 配置
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>1.1.9</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.1.9</version>
</dependency>
同时配置logback.xml的配置文件,即可使用slf4j管理日志系统,同时如果想要切换日志系统,例如 想要切换到log4j,无需修改代码,只需将上述logback dependency删除,增加log4j的配置
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.21</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
可以实现不修改代码,更改日志系统的功能。
slf4j集成log4j所需jar包及maven配置
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.21</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.21</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
所需外部支持可分为三部分:slf4j-api包 log4j包 以及slf4j-log4j12guanlainbao
slf4j及log4j配置文件
在 src/main/resources中 new–>resource bundle —->写入文件名 log4j 生成log4j.properties文件
### config root logger
log4j.rootLogger=info, STDOUT
配置根logger 格式为 [level],appenderName1,appenderName2……
其中[level]共分为5级,如下:
FATAL 0
ERROR 3
WARN 4
INFO 6
DEBUG 7
appendername是配置日志输出的目的地
log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender
log4j.appender.STDOUT.Target=System.out
log4j.appender.STDOUT.layout=org.apache.log4j.PatternLayout
log4j.appender.STDOUT.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p %c{1}:%L - %m%n
其中appender的类型有如下几种:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
输出格式layout有如下几种
org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
打印参数配置如下:
%m 输出代码中指定的消息
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss , SSS},输出类似:2002年10月18日 22 : 10 : 28 , 921
%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java: 10 )
输出到文件中示例:
### 输出到日志文件 ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG ## 输出DEBUG级别以上的日志
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
slf4j集成log4j
约定大于配置,如果将log4j.properties放置在classpath中,即resources文件夹下 可自动读取
private static final Logger logger= LoggerFactory.getLogger(TestUtil.class);
public static void main(String [] args){
logger.info("info信息");
logger.debug("debug信息");
}