在项目中,对log的输出有多种多样的要求,下面具体分析一下动态log文件名输出的。:
一、按照用户ID来生成log,可以根据每个用户ID来动态生成logger。
代码如下:
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.apache.log4j.PatternLayout;
import org.apache.log4j.RollingFileAppender;
public class LoggerUtil {
public static Logger getLoggerByName(String name) {
// 生成新的Logger
// 如果已经有了一个Logger实例返回现有的
Logger logger = Logger.getLogger(name);
// 清空Appender。特别是不想使用现存实例时一定要初期化
logger.removeAllAppenders();
// 设定Logger级别。
logger.setLevel(Level.DEBUG);
// 设定是否继承父Logger。
// 默认为true。继承root输出。
// 设定false后将不输出root。
logger.setAdditivity(true);
// 生成新的Appender
RollingFileAppender appender = new RollingFileAppender();
PatternLayout layout = new PatternLayout();
// log的输出形式
String conversionPattern = ""[%d{yy/MM/dd HH:mm:ss:SSS}] [%p] [%c-%t] %m%n"";
layout.setConversionPattern(conversionPattern);
appender.setLayout(layout);
// log输出路径
// 这里使用了环境变量[catalina.home],只有在tomcat环境下才可以取到
String tomcatPath = java.lang.System.getProperty("catalina.home");
appender.setFile(tomcatPath + "/logs/" + name + ".log");
// log的文字码
appender.setEncoding("UTF-8");
//设定log文件大小和备份数量
appender1.setMaxFileSize("1KB");
appender1.setMaxBackupIndex(1);
// true:在已存在log文件后面追加 false:新log覆盖以前的log
appender.setAppend(true);
// 适用当前配置
appender.activateOptions();
// 将新的Appender加到Logger中
logger.addAppender(appender);
return logger;
}
}
二、在batch程序中,通过一个设定来实现每个batch,文件名不同的设定
log.xml定义
<appender name="daily" class="org.apache.log4j.DailyRollingFileAppender">
<param name="file" value="/opt/tuhan.crm/batch/log/${tuhan.crm.log.name}.log" />
<param name="threshold" value="debug"/>
<param name="DatePattern" value="yyyyMMdd"/>
<param name="append" value="true" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%d{yyyy-MMM-dd HH:mm:ss,SSS}\t[%-5p]\t(%c:%L)\t%m%n"/>
</layout>
</appender>
log4j可以接受自定义环境变量,注意下面行【${tuhan.crm.log.name}】就是自定义环境变量
<param name="file" value="/opt/tuhan.crm/batch/log/${tuhan.crm.log.name}.log" />
那么环境变量如何设置呢,有2种方法
1、Java中设定(在使用配置文件之前, 要在程序中声明这些变量):
System.setProperty("tuhan.crm.log.name", "batch001");
2、在JVM设定
java -Xmx512M -Dtuhan.crm.log.name=batch001 com.stu.TestBatch001
三、在batch程序中,通过多个设定来实现每个batch,文件名不同的设定
动态的配置文件路径: (log4j可以接受URL)
java.net.URL URL = consandpatt.class.getResource("/com/test/java/log/config/log4jConfig.properties");
PropertyConfigurator.configure(URL);