2013-07-04 1 views
1

У меня есть требование обработать файл flatfile путем выполнения весеннего пакетного задания. Я получаю список файлов из папки, которую нужно обработать. Пожалуйста, дайте мне знать, как это сделать.Список ресурсов для выполнения весеннего пакетного задания

Например:
У меня есть player.csv и player1.csv и player2.csv в папке. У меня есть эти имена файлов в списке. Пожалуйста, дайте мне знать, могу ли я ввести все эти имена файлов для Jobparameters, чтобы я мог выполнить одно задание?

JobParameters jobParameters = new JobParametersBuilder().addString("input.file", "file:player.csv").toJobParameters(); 
JobExecution execution = jobLauncher.run(job,jobParameters); 
assertEquals(ExitStatus.COMPLETED, execution.getExitStatus()); 

ответ

2

есть несколько способов, которыми вы можете это сделать; 1. Создайте задание для обработки одного файла за раз и попросите инициатора вашего проекта выполнить итерацию по файлам и запустить задание, передавая только один файл за один раз. 2. создайте «петлю» внутри своей работы, чтобы перейти значения и обрабатывать каждый файл

вот пример последнего варианта;

сначала конфигурация задания - он использует решающий элемент для создания значения контекста выполнения для обрабатываемого файла. если нет больше файлов (от jobParameter), то он заканчивает

<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:batch="http://www.springframework.org/schema/batch" 
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd 
     http://www.springframework.org/schema/batch http://www.springframework.org/schema/batch/spring-batch.xsd"> 

    <batch:job id="multipleFileProcess"> 
     <batch:decision decider="decider" id="multipleFileProcess.decider"> 
      <batch:next on="UNKNOWN" to="multipleFileProcess.step1"/> 
      <batch:end on="COMPLETED"/> 
     </batch:decision> 
     <batch:step id="multipleFileProcess.step1" next="multipleFileProcess.decider"> 
      <batch:tasklet> 
       <batch:chunk reader="fileReader" writer="outWriter" commit-interval="10"/> 
      </batch:tasklet> 
     </batch:step> 
     <batch:validator> 
      <bean class="org.springframework.batch.core.job.DefaultJobParametersValidator"> 
       <property name="requiredKeys" value="input.files"/> 
      </bean>   
     </batch:validator> 
    </batch:job> 


    <bean id="fileReader" 
     class="org.springframework.batch.item.file.FlatFileItemReader" scope="step"> 
     <property name="lineMapper" ref="lineMapper"/> 
     <property name="resource" value="file:#{jobExecutionContext['input.file']}"/> 
    </bean> 

    <bean id="lineMapper" 
     class="org.springframework.batch.item.file.mapping.PassThroughLineMapper"/> 


    <bean id="transactionManager" 
     class="org.springframework.batch.support.transaction.ResourcelessTransactionManager"> 
    </bean> 

    <bean id="decider" class="de.incompleteco.spring.batch.decider.FileDecision"/> 

    <bean id="outWriter" class="de.incompleteco.spring.batch.item.writer.SystemOutItemWriter"/> 

</beans> 

вот код решающего (используя внутреннюю очередь - это, вероятно, будет безопаснее, чтобы сохранить эту «очередь» в качестве строки в контексте выполнения что вы медленно укоротить (вручную «поп» запись строки - но для быстроты используются очередь)

package de.incompleteco.spring.batch.decider; 

import java.util.Arrays; 
import java.util.Queue; 
import java.util.concurrent.LinkedBlockingQueue; 

import org.springframework.batch.core.JobExecution; 
import org.springframework.batch.core.StepExecution; 
import org.springframework.batch.core.job.flow.FlowExecutionStatus; 
import org.springframework.batch.core.job.flow.JobExecutionDecider; 

public class FileDecision implements JobExecutionDecider { 

    public static final String INPUT_FILE = "input.file"; 
    public static final String INPUT_FILES = "input.files"; 
    public static final String DELIMITER = ","; 

    private Queue<String> inputFiles; 

    @Override 
    public FlowExecutionStatus decide(JobExecution jobExecution,StepExecution stepExecution) { 
     //check if the jobExecution has the input.file in it's context 
     if (!jobExecution.getExecutionContext().containsKey(INPUT_FILE)) { 
      //build the queue 
      inputFiles = new LinkedBlockingQueue<String>(Arrays.asList(jobExecution.getJobParameters().getString(INPUT_FILES).split(DELIMITER))); 
     }//end if 
     //pop and add 
     String file = inputFiles.poll(); 
     if (file != null) { 
      jobExecution.getExecutionContext().put(INPUT_FILE, file); 
      return FlowExecutionStatus.UNKNOWN; 
     }//end if 
     //return 'done' 
     return FlowExecutionStatus.COMPLETED; 
    } 

} 

вот фиктивный «писатель», чтобы показать файл как его «написано» из

package de.incompleteco.spring.batch.item.writer; 

import java.util.List; 

import org.springframework.batch.item.ItemWriter; 

public class SystemOutItemWriter implements ItemWriter<String> { 

    @Override 
    public void write(List<? extends String> items) throws Exception { 
     for (String item : items) { 
      System.out.println("this is what was received:" + item); 
     }//end for 
    } 

} 

и, наконец, модульный тест, чтобы проверить, не работает ли это

package de.incompleteco.spring.batch; 

import static org.junit.Assert.assertFalse; 

import java.io.File; 
import java.io.FileWriter; 

import javax.annotation.Resource; 

import org.junit.Rule; 
import org.junit.Test; 
import org.junit.rules.TemporaryFolder; 
import org.junit.runner.RunWith; 
import org.springframework.batch.core.Job; 
import org.springframework.batch.core.JobExecution; 
import org.springframework.batch.core.JobParameters; 
import org.springframework.batch.core.JobParametersBuilder; 
import org.springframework.batch.core.explore.JobExplorer; 
import org.springframework.batch.core.launch.JobLauncher; 
import org.springframework.test.context.ContextConfiguration; 
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; 

import de.incompleteco.spring.batch.decider.FileDecision; 

@RunWith(SpringJUnit4ClassRunner.class) 
@ContextConfiguration("classpath:/META-INF/spring/*-context.xml") 
public class MultipleFileProcessIntegrationTest { 

    @Rule 
    public TemporaryFolder folder = new TemporaryFolder(); 

    @Resource 
    private Job job; 

    @Resource 
    private JobLauncher jobLauncher; 

    @Resource 
    private JobExplorer jobExplorer; 

    @Test 
    public void test() throws Exception { 
     //somewhere to hold the filenames 
     StringBuilder builder = new StringBuilder(); 
     //create 3 files 
     for (int i=0;i<3;i++) { 
      File file = folder.newFile("testfile" + i + ".txt"); 
      //write some content 
      FileWriter writer = new FileWriter(file); 
      writer.write("test content: " + i); 
      writer.flush(); 
      writer.close(); 
      //add the filename 
      if (i > 0) { 
       builder.append(FileDecision.DELIMITER); 
      }//end if 
      builder.append(file.getAbsolutePath()); 
      //show it 
      System.out.println(file.getAbsolutePath()); 
     }//end loop 


     //now build the job parameters 
     JobParameters parameters = new JobParametersBuilder().addString(FileDecision.INPUT_FILES,builder.toString()).toJobParameters(); 
     //execution 
     JobExecution execution = jobLauncher.run(job,parameters); 
     //check 
     while (jobExplorer.getJobExecution(execution.getId()).isRunning()) { 
      Thread.sleep(100); 
     }//end while 
     //load 
     execution = jobExplorer.getJobExecution(execution.getId()); 
     //check 
     assertFalse(execution.getStatus().isUnsuccessful()); 
    } 

} 
+1

+1 для принятия решения. – Cygnusx1