Maven项⽬下使⽤log4j
Apache Log4j是⼀个基于Java的⽇志记录⼯具,它的⽇志级别按下⾯顺序递减:
级别描述
OFF最⾼级别,⽤于关闭⽇志记录。
FATAL将导致应⽤程序提前终⽌的严重错误的信息将⽴即呈现在⽇志上。
ERROR将其他运⾏时错误或意外情况的信息呈现在⽇志上。
WARN使⽤已过时的API,API的滥⽤,潜在错误,其他不良的或意外的运⾏时的状况(但不⼀定是错误的)
INFO⼀些感兴趣的运⾏时事件(启动/关闭
DEBUG⼀些详细信息,查看程序的运⾏状态
TRACE最详细的信息。⼀般这些信息只记录到⽇志⽂件中。
下⾯介绍如何在java项⽬中如何使⽤Log4j。
1. 配置maven,引⼊jar包
<dependencies>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
</dependencies>
2. 配置log4j的配置⽂件
其配置⽂件名为log4j.properties,需要⼿动在java/resources下创建,如果建在其他位置,idea这个⼯具将⽆法识别(如果⽆法识别后⾯会介绍怎么解决)。下⾯介绍该配置⽂件的⼏个基本配置项。
a. ⽇志的输出的⽬的地
形式描述
org.apache.log4j.ConsoleAppender控制台
org.apache.log4j.FileAppender⽂件
org.apache.log4j.DailyRollingFileAppender每天产⽣⼀个⽇志⽂件
org.apache.log4j.RollingFileAppender⽂件⼤⼩到达指定尺⼨的时候产⽣⼀个新的⽂件
org.apache.log4j.WriterAppender将⽇志信息以流格式发送到任意指定的地⽅
b. Layout:⽇志输出格式
形式描述
org.apache.log4j.HTMLLayout以HTML表格形式布局
org.apache.log4j.PatternLayout可以灵活地指定布局模式
org.apache.log4j.SimpleLayout包含⽇志信息的级别和信息字符串
org.apache.log4j.TTCCLayout包含⽇志产⽣的时间、线程、类别等等信息
c. 格式化⽇志信息
采⽤类似C语⾔中的printf函数的打印格式格式化⽇志信息
形式描述
%d输出⽇志时间点的⽇期或时间,可以在其后指定格式,⽐如:%d{yyy MMM dd HH:mm:ss , SSS}
%t输出产⽣该⽇志事件的线程名
%p优先级 DEBUG/INFO/ERROR
%c所属类的全名(包括包名)
%l发⽣的位置,在某个类的某⾏
%m输出代码中指定的讯息,如log(message)中的message
%n输出⼀个换⾏符号
案例
案例使⽤如下的配置信息:
log4j2 appender### set log levels ###
### 输出到控制台 ###
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
3. 使⽤Log4j
配置完上⾯信息后就可以创建⼀个Java⽂件去测试⽇志的⽂件的使⽤了。
package st;
import org.apache.log4j.Logger;
public class Hello {
private static Logger log = Logger(Class());
public static void main(String[] args) {
log.debug("");
<("");
}
}
结果如图左侧(左上是控制台的log,左下是app.log⽂件的log),其中整个⼯程的布局如图右侧:
4 . 问题
过程中可能出现下⾯的问题:
log4j:WARN No appenders could be found for logger (java.lang.Class).
log4j:WARN Please initialize the log4j system properly. log4j:WARN See /log4j/1.2/faq.html#noconfig for more info.
这个其实是IDE(Idea)不到log4j的properties⽂件,有些博客说可以去project_structure去改配置,尝试了⼀下可惜没有⽤,但发现了可以在程序中通过代码去指定properties⽂件的位置,如果出现了上⾯的错误,可以改成如下形式:
package st;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
public class Hello {
private static Logger log = Logger(Class());
public static void main(String[] args) {
//获取当前项⽬的根⽬录
String Property("user.dir");
log.debug("");
<("");
}
}
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论