可以先熟悉一下jdk的logging,对于理解log4j有很大帮助
java核心基础–jdk源码分析学习–logger使用简单分析
log4j:WARN No appenders could be found for logger (Test).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
如果出现上面的警告,就是没有配置文件或,配置文件错误,【log4j必须配置后才能用】
默认配置文件【log4j.properties】或【log4j.xml】,放到类的根目录,src或者maven的resources下
【默认配置样例】
#log4j.properties
#root或项目总体 log最低级别info,ma是一个appender
log4j.rootCategory=info, ma
#Test类的log最低级别
log4j.logger.Test=info
#包a下类的log最低级别
log4j.logger.a=debug
#设置一个ma的appender,相当于jdk logging里的handler,对日志的最终处理
log4j.appender.ma=org.apache.log4j.ConsoleAppender
log4j.appender.ma.Target=System.err
log4j.appender.ma.layout=org.apache.log4j.PatternLayout
log4j.appender.ma.layout.ConversionPattern=%d{ABSOLUTE} %5p - %m%n
log4j可以在配置 [log4j.properties] 中【打开自身debug选项】,查看log4j执行过程
#老版本
log4j.configDebug=true
#新版本建议
log4j.debug=true
【基本使用】
import org.apache.log4j.Logger;
public class Test {
private static Logger log = Logger.getLogger(Test.class);
public void myfunc(){
log.debug("test debug");
log.info("in myfunc");
}
}