Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/spring/14.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/spring-mvc/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Spring批处理集log4j文件追加器名称来自#{jobParameters[';';]}_Java_Spring_Log4j_Spring Batch - Fatal编程技术网

Java Spring批处理集log4j文件追加器名称来自#{jobParameters[';';]}

Java Spring批处理集log4j文件追加器名称来自#{jobParameters[';';]},java,spring,log4j,spring-batch,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

我有这个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必须写入的日志文件的路径

我该怎么办


谢谢。

我们可以通过定义作业侦听器来实现这一点。下面是示例。如果只想使用新的附加器,请确保删除现有的附加器

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));
                }
            }
    }
}
公共类CommonLoggerListener实现JobExecutionListener{
@值(“#{jobParameters['LOG_FILE_NAME']}”)
字符串文件名;
@凌驾
作业前公共无效(作业执行作业执行){
Logger Logger=LoggerFactory.getLogger(“com.demo”);
类loggerIntrospected=logger.getClass();
字段字段[]=LoggerInterspected.getDeclaredFields();
for(int i=0;i