日志就是记录程序的运行轨迹,方便快速定位问题
如果用System.out.println(),信息是打印在控制台。等到产品上线后没有控制台,如果有报错信息,根本不知道去哪里看,就不知道是哪里出错。
而且开发的时候希望打印输出的内容多。方便排查,上线后只希望打印容易出错的部分。System.out.println()满足不了这个需求
而日志框架可以让错误信息输出到多个指定文件,不同的文件有不同的输出内容。方便排错,定位错误
一、log4j介绍
Log4j有三个主要的组件/对象:Loggers(记录器),Appenders (输出源)和Layouts(布局)。这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出。
每条日志语句都要设置一个等级(DEBUG、INFO、WARN、ERROR和FATAL)。
其中DEBUG < INFO < WARN < ERROR < FATAL。fatal等级最高
对应调试信息 一般信息 警告信息 错误信息 严重错误信息
1、Loggers
在设置日志输出位置的时候,会给那个位置设置一个级别,只有大于等于那个级别的日志才会打印输出到指定位置。
例如:某个Loggers(日志输出位置的等级记录器)级别设定为INFO,则INFO、WARN、ERROR和FATAL级别的日志信息都会输出到那个文件,而级别比INFO低的DEBUG则不会输出。
2、Appenders
禁用和使用日志请求只是Log4j的基本功能,Log4j日志系统还提供许多强大的功能,比如允许把日志输出到不同的地方,如控制台(Console)、文件(Files)等,可以根据天数或者文件大小产生新的文件,可以以流的形式发送到其它地方等等。
常使用的类如下:
org.apache.log4j.ConsoleAppender(控制台)
org.apache.log4j.FileAppender(文件)
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
基本上可以满足我们的日常需求,当然如果你的需求比较特殊,可以自己实现Appender输出路径。只需要定义一个类,实现Appender接口就可以了。Appender接口中定义了一系列记录日志的方法,按照自己的规则实现这些方法即可
3、Layouts
用户可以根据自己的喜好格式化自己的日志输出,Layouts提供四种日志输出样式,如根据HTML样式、自由指定样式、包含日志级别与信息的样式和包含日志时间、线程、类别等信息的样式。
常使用的类如下:
org.apache.log4j.HTMLLayout(以HTML表格形式布局)
org.apache.log4j.PatternLayout(可以灵活地指定布局模式)
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等信息)
二、使用
在实际应用中,要使Log4j在系统中运行必须事先设定配置文件。配置文件事实上也就是对Logger、Appender及Layout进行相应设定。Log4j支持两种配置文件格式,一种是XML格式的文件,一种是properties属性文件,配置文件详解在下面使用部分说明
我是用maven创建项目
1、导包
在pom.xml
<dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency>
2、创建配置文件
日志配置文件:log4j.properties文件或者logback.xml。
我用的是log4j.properties
在普通的se项目中放到src同级目录下,maven项目中放到src/main/resources目录下
### 日志的输出级别是dubug,输出位置名字叫stdout,D log4j.rootLogger = debug,stdout,D ### 输出信息到控制抬 ### log4j.appender.stdout = org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target = System.out #用特定格式输出日志 log4j.appender.stdout.layout = org.apache.log4j.PatternLayout #下面是规定好的格式,有点像c语言printf的%d,%m是输出代码中指定的消息的占位符 log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n ### 输出warn 级别以上的日志到文件里 # 文件位置为:D:/logs/error.log4j log4j.appender.D = org.apache.log4j.FileAppender log4j.appender.D.File = D:/logs/error.log4j log4j.appender.D.Append = true log4j.appender.D.Threshold = warn 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
3、使用
在代码中使用Log4j
public class Test { @org.junit.Test public void testLog(){ //1、获取日志记录器,这个记录器将负责控制日志信息 //Name一般取当前类的名字 Logger logger = Logger.getLogger(Test.class); //直接使用日志记录器,打印日志 logger.debug("dubug级别"); logger.error("error级别"); } }
最后结果:
控制台输出
磁盘中的文件输出
-------------------------------下面的太复杂------------------------------------
https://www.zzvips.com/article/134950.htm
https://www.zzvips.com/article/121581.htm
###配置日志根Logger #第一参数是日志输出级别,这里是一个全局级别,只要它指定了error,下面不管设置什么比它的低级别都会失效,所以一般指定dubug #后面几个参数都是日志输出的位置,多个输出路径用,隔开;随便起名只是一个代号 log4j.rootLogger=DEBUG,out1,out2,out3,out4 #ERROR 为严重错误 主要是程序的错误 #WARN 为一般警告,比如session丢失 #INFO 为一般要显示的信息,比如登录登出 #DEBUG 为程序的调试信息 #表示Logger的内容不会在父Logger的appender里输出,默认为true。 (?可能是这样,要输出日志时,得先创建一个Logger对象,用Logger对象打印,如果这里是true,日志内容不仅会出现在当前配置的日志文件里,还会出现在父类的日志文件里) log4j.additivity.org.apache=false
下面的输出位置名字分别是 out1,out2,out3,out4
###配置日志信息输出目的地Appender,appender后面的参数对应log4j.rootLogger的位置名称 log4j.appender.out1=org.apache.log4j.ConsoleAppender #打印到控制台 log4j.appender.out1.Threshold=DEBUG #指定日志信息的最低输出级别,默认为DEBUG。 log4j.appender.out1.ImmediateFlush=true #表示所有消息都会被立即输出,设为false则不输出,默认值是true。 log4j.appender.out1.Target=System.err #默认值是System.out。?不知道是什么 log4j.appender.out1.layout=org.apache.log4j.PatternLayout #可以灵活地指定布局模式 log4j.appender.out1.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n #布局格式 # 日志文件(logFile) log4j.appender.logFile=org.apache.log4j.FileAppender log4j.appender.logFile.Threshold=DEBUG log4j.appender.logFile.ImmediateFlush=true log4j.appender.logFile.Append=true log4j.appender.logFile.File=D:/logs/log.log4j log4j.appender.logFile.layout=org.apache.log4j.PatternLayout log4j.appender.logFile.layout.ConversionPattern=[%-5p] %d(%r) --> [%t] %l: %m %x %n ### 输出到日志文件 ### #org.apache.log4j.ConsoleAppender #org.apache.log4j.FileAppender(文件) #org.apache.log4j.DailyRollingFileAppender #org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件) #org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方) #log4j.appender.error.Target=System.out
logback.xml可以看:https://www.zzvips.com/article/186698.html
使用
在不同环境使用日志框架:https://www.zzvips.com/article/47948.html
https://www.zzvips.com/article/186698.html
https://www.zzvips.com/article/201537.html
到此这篇关于在Java中使用日志框架log4j的文章就介绍到这了,更多相关Java日志框架log4j内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/qq_43496435/article/details/119252266