背景:将程序发布时,默认log4j的配置文件也要一同被打入jar包才可能被读取到,要想将log4j的配置文件放在jar包外可以通过以下的代码手动指定log4j配置文件的位置
// log4j的配置文件放在jar包所在目录下的conf目录中
//将以下代码放在main函数所在类中:
// 代码实例1:DOMConfigurator载入log4j.xml
static {
DOMConfigurator.configure(System.getProperty(“user.dir”) + File.separator + “conf” + File.separator
- “log4j.xml”);
}
// 代码实例2:PropertyConfigurator载入log4j.properties文件。
static {
PropertyConfigurator.configure(System.getProperty(“user.dir”) + File.separator + “conf” + File.separator - “log4j.properties”);
}
// 代码实例3:PropertyConfigurator另一种指定方式
private static Logger logger = Logger.getLogger(Transfer.class);
PropertyConfigurator.configure(Props.getString(“log4jforerror”));
logger.debug(“这里记录debug级别的日志”);
logger.error(“这里记录error级别的日志”);
// log4j.properties 的配置示范
设置日志级别
log4j.rootLogger = debug,stdout,D,E
输出信息到控制台
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 = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
输出DEBUG 级别以上的日志到=./logs/log.log
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
#log4j.appender.D.File = C:\mysqltomongodb\logs\log.log
log4j.appender.D.File = /opt/facedatatransfer/logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = 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
输出ERROR 级别以上的日志到=./logs/error.log
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
#log4j.appender.E.File =C:\mysqltomongodb\logs\error.log
log4j.appender.E.File = /opt/facedatatransfer/logs/error.log
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n