개발/스프링

[SPRING BOOT] SPRING BATCH + SCHEDULER

로그인시러 2016. 8. 3. 13:36

scheduler를 통해서 batch 가 돌고, 

rest 기능을 수행하는 서버를 

spring boot 를 통해서 만들어야 할 일이 생겼다.

 

일단, maven !

 

  		 			org.springframework.boot 			spring-boot-starter-batch 		 		 			org.springframework.boot 			spring-boot-starter-web 		  		 			org.springframework.boot 			spring-boot-starter-test 			test 		 		 		 		 			org.codehaus.janino 			janino 		 		 		 		 			org.mybatis.spring.boot 			mybatis-spring-boot-starter 			1.0.0 		 		 		 			org.projectlombok 			lombok 			1.16.4 			provided 		 		 		 			com.oracle 			ojdbc6 			11.1.0.7.0 		 

 

 

보다시피, 기본 spring boot 설정에

spring-boot-starter-batch, spring-boot-starter-web 설정만 추가하였다.

헐 ~ 편하다. 개꿀이네ㅋㅋ

 

일단, batch를 schedule 하기 위해서는

JobLauncher 가 필요하다.

 

다음은 JobLaucher 를 위한 각종 bean에 대한 java config 이다.

 

@Configuration @EnableScheduling public class BatchScheduler { 	@Bean     public ResourcelessTransactionManager transactionManager() {         return new ResourcelessTransactionManager();     }      @Bean     public MapJobRepositoryFactoryBean mapJobRepositoryFactory(             ResourcelessTransactionManager txManager) throws Exception {                  MapJobRepositoryFactoryBean factory = new                  MapJobRepositoryFactoryBean(txManager);                  factory.afterPropertiesSet();                  return factory;     }      @Bean     public JobRepository jobRepository(             MapJobRepositoryFactoryBean factory) throws Exception {         return factory.getObject();     }      @Bean     public SimpleJobLauncher jobLauncher(JobRepository jobRepository) {         SimpleJobLauncher launcher = new SimpleJobLauncher();         launcher.setJobRepository(jobRepository);         return launcher;     } } 

 

 

설정한 JobLaucher 는 Batch Configuration 클래스에서 아래와 같이 사용한다.

 

 

  @Configuration @EnableBatchProcessing @EnableScheduling @Slf4j //@Import({BatchScheduler.class}) public class ETLBatchConf {  	@Autowired 	public JobBuilderFactory jobBuilderFactory;  	@Autowired 	public StepBuilderFactory stepBuilderFactory; 	     @Autowired     private SimpleJobLauncher jobLauncher;  	@Bean 	public ETLReader etlReader() { 		return new ETLReader(); 	}  	@Bean 	public ItemWriter etlWriter() { 		// TODO Auto-generated method stub 		return new ETLWriter(); 	}  	@Bean 	public ETLProcessor etlProcessor() { 		// TODO Auto-generated method stub 		return new ETLProcessor(); 	}  	@Bean 	public JobExecutionListener etlListener() { 		return new ETLJobCompletionListener(); 	}  	// Configure job step 	@Bean //	public Job etlJob(@Qualifier("etlStep") Step step) { 	public Job etlJob() { 		return jobBuilderFactory.get("[ETL JOB]") 				.incrementer(new RunIdIncrementer()) 				.listener(etlListener()) 				.start(etlStep()) 				.build(); 		 		//start().next().next()  	}  	@Bean 	public Step etlStep() { 		return stepBuilderFactory.get("[ETL]") 				.<inputtype, outputtype=""> chunk(2) 				.reader(etlReader()) 				.processor(etlProcessor()) 				.writer(etlWriter()) 				.build(); 	}  	 //	@Scheduled(cron = "1 53/3 17 * * ?") 	@Scheduled(cron = "0 51 14 * * ?")     public void perform() throws Exception {         log.info("Job Started at :" + new Date());          JobParameters param = new JobParametersBuilder().addString("JobID",                 String.valueOf(System.currentTimeMillis())).toJobParameters();          JobExecution execution = jobLauncher.run(etlJob(), param);          log.info("Job finished with status :" + execution.getStatus());     } 	 } </inputtype,>

 

 

이외에 batch job 을 추가로 설정하고 싶을 수 있다.

아래는 tasklet 을 구현한 클래스로 설정하는 과정이다.

 

@Configuration @EnableBatchProcessing @EnableScheduling @Slf4j public class AnalysisBatchConf { 	@Autowired 	public JobBuilderFactory jobBuilderFactory;  	@Autowired 	public StepBuilderFactory stepBuilderFactory; 	     @Autowired     private SimpleJobLauncher jobLauncher;      @Scheduled(cron = "0 10 18 * * ?")     public void perform() throws Exception {         log.info("Job Started at :" + new Date());          JobParameters param = new JobParametersBuilder().addString("JobID",                 String.valueOf(System.currentTimeMillis())).toJobParameters();          JobExecution execution = jobLauncher.run(analysisJob(), param);          log.info("Job finished with status :" + execution.getStatus());     }  	private Job analysisJob() { 		// TODO Auto-generated method stub 		return jobBuilderFactory.get("[ANALYSIS JOB]") 				.incrementer(new RunIdIncrementer()) 				.start(analysisStep()) 				.build(); 	}  	private Step analysisStep() { 		// TODO Auto-generated method stub 		return stepBuilderFactory.get("[ANALYSIS]") 				.tasklet(new AnalysisTask()) 				.build(); 	}  }