Spring批量设置来自#{jobParameters ['']}的log4j文件追加者名称

时间:2018-04-23 15:02:56

标签: java spring log4j spring-batch

我有这个log4j属性配置:

log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=${logfilepath}
log4j.appender.file.MaxFileSize=10MB
log4j.appender.file.MaxBackupIndex=10
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

我还有这个#{jobParameters['logfilepath']},其中包含我希望log4j写入我的批处理日志的文件路径。

如何将此值传递给log4j.properties文件?

我想通过命令行参数指定log4j必须写入的日志文件的路径。

我该怎么办?

感谢。

1 个答案:

答案 0 :(得分:0)

我们可以通过定义一个工作监听器来做到这一点。以下示例。如果您只想使用新的appender,请务必删除现有的appender。

public class CommonLoggerListener implements JobExecutionListener{

    @Value("#{jobParameters['LOG_FILE_NAME']}")
    String fileName;

    @Override
    public void beforeJob(JobExecution jobExecution) {
       Logger logger = LoggerFactory.getLogger("com.demo");
       Class loggerIntrospected = logger.getClass();
       Field fields[] = loggerIntrospected.getDeclaredFields();
       for (int i = 0; i < fields.length; i++) {
                String fieldName = fields[i].getName();
                if (fieldName.equals("logger")) {
                    fields[i].setAccessible(true);
                    org.apache.log4j.Logger loggerImpl = (org.apache.log4j.Logger) fields[i].get(logger);
                    loggerImpl.addAppender(new RollingFileAppender(<layout>, fileName));
                }
            }
    }
}