Apache Log4j是一个基于Java的日志记录工具,它的日志级别按下面顺序递减:html
级别 | 描述 |
---|---|
OFF | 最高级别,用于关闭日志记录。 |
FATAL | 将致使应用程序提早终止的严重错误的信息将当即呈如今日志上。 |
ERROR | 将其余运行时错误或意外状况的信息呈如今日志上。 |
WARN | 使用已过期的API,API的滥用,潜在错误,其余不良的或意外的运行时的情况(但不必定是错误的) |
INFO | 一些感兴趣的运行时事件(启动/关闭 |
DEBUG | 一些详细信息,查看程序的运行状态 |
TRACE | 最详细的信息。通常这些信息只记录到日志文件中。 |
下面介绍如何在java项目中如何使用Log4j。java
<dependencies> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> </dependencies>
其配置文件名为log4j.properties,须要手动在java/resources下建立,若是建在其余位置,idea这个工具将没法识别(若是没法识别后面会介绍怎么解决)。下面介绍该配置文件的几个基本配置项。apache
形式 | 描述 |
---|---|
org.apache.log4j.ConsoleAppender | 控制台 |
org.apache.log4j.FileAppender | 文件 |
org.apache.log4j.DailyRollingFileAppender | 天天产生一个日志文件 |
org.apache.log4j.RollingFileAppender | 文件大小到达指定尺寸的时候产生一个新的文件 |
org.apache.log4j.WriterAppender | 将日志信息以流格式发送到任意指定的地方 |
形式 | 描述 |
---|---|
org.apache.log4j.HTMLLayout | 以HTML表格形式布局 |
org.apache.log4j.PatternLayout | 能够灵活地指定布局模式 |
org.apache.log4j.SimpleLayout | 包含日志信息的级别和信息字符串 |
org.apache.log4j.TTCCLayout | 包含日志产生的时间、线程、类别等等信息 |
采用相似C语言中的printf函数的打印格式格式化日志信息app
形式 | 描述 |
---|---|
%d | 输出日志时间点的日期或时间,能够在其后指定格式,好比:%d{yyy MMM dd HH:mm:ss , SSS} |
%t | 输出产生该日志事件的线程名 |
%p | 优先级 DEBUG/INFO/ERROR |
%c | 所属类的全名(包括包名) |
%l | 发生的位置,在某个类的某行 |
%m | 输出代码中指定的讯息,如log(message)中的message |
%n | 输出一个换行符号 |
案例使用以下的配置信息:maven
### set log levels ### log4j.rootLogger = DEBUG,Console,File ### 输出到控制台 ### log4j.appender.Console=org.apache.log4j.ConsoleAppender log4j.appender.Console.Target=System.out log4j.appender.Console.layout=org.apache.log4j.PatternLayout log4j.appender.Console.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}]-%l:%m%n ### 输出到日志文件 ### log4j.appender.File=org.apache.log4j.RollingFileAppender log4j.appender.File.File=${project}src\\main\\resources\\app.log log4j.appender.File.MaxFileSize=10MB log4j.appender.File.Threshold=ALL log4j.appender.File.layout=org.apache.log4j.PatternLayout log4j.appender.File.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n
配置完上面信息后就能够建立一个Java文件去测试日志的文件的使用了。ide
package com.gqx.test; import org.apache.log4j.Logger; public class Hello { private static Logger log = Logger.getLogger(Hello.class.getClass()); public static void main(String[] args) { log.debug("debug..."); log.error("error..."); } }
结果如图左侧(左上是控制台的log,左下是app.log文件的log),其中整个工程的布局如图右侧:函数
过程当中可能出现下面的问题:工具
log4j:WARN No appenders could be found for logger (java.lang.Class).
log4j:WARN Please initialize the log4j system properly. log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
这个实际上是IDE(Idea)找不到log4j的properties文件,有些博客说能够去project_structure去改配置,尝试了一下惋惜没有用,但发现了能够在程序中经过代码去指定properties文件的位置,若是出现了 上面的错误,能够改为以下形式:布局
package com.gqx.test; import org.apache.log4j.Logger; import org.apache.log4j.PropertyConfigurator; public class Hello { private static Logger log = Logger.getLogger(Hello.class.getClass()); public static void main(String[] args) { //获取当前项目的根目录 String relativelyPath=System.getProperty("user.dir"); PropertyConfigurator.configure(relativelyPath+ "\\src\\main\\resources\\log4j.properties"); log.debug("debug..."); log.error("error..."); } }
原文出处:https://www.cnblogs.com/helloworldcode/p/11699105.html测试