oom처리
This commit is contained in:
@@ -0,0 +1,64 @@
|
|||||||
|
package com.kamco.makesample.batch.tasklet;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
import org.springframework.batch.core.StepContribution;
|
||||||
|
import org.springframework.batch.core.configuration.annotation.StepScope;
|
||||||
|
import org.springframework.batch.core.scope.context.ChunkContext;
|
||||||
|
import org.springframework.batch.core.step.tasklet.Tasklet;
|
||||||
|
import org.springframework.batch.repeat.RepeatStatus;
|
||||||
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
|
import org.springframework.jdbc.core.JdbcTemplate;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Shapefile 생성 완료 후 실행되는 UPDATE Tasklet
|
||||||
|
*
|
||||||
|
* <p>Job Flow 상 generateShapefileStep 이후에 실행됩니다.
|
||||||
|
*
|
||||||
|
* <p>실행할 SQL은 이 클래스의 execute() 메서드 안에 작성하세요.
|
||||||
|
*/
|
||||||
|
@Component
|
||||||
|
@StepScope
|
||||||
|
public class PostShapefileUpdateTasklet implements Tasklet {
|
||||||
|
|
||||||
|
private static final Logger log = LoggerFactory.getLogger(PostShapefileUpdateTasklet.class);
|
||||||
|
|
||||||
|
private final JdbcTemplate jdbcTemplate;
|
||||||
|
|
||||||
|
@Value("#{jobParameters['inferenceId']}")
|
||||||
|
private String inferenceId;
|
||||||
|
|
||||||
|
@Value("#{jobParameters['batchIds']}")
|
||||||
|
private String batchIds;
|
||||||
|
|
||||||
|
public PostShapefileUpdateTasklet(JdbcTemplate jdbcTemplate) {
|
||||||
|
this.jdbcTemplate = jdbcTemplate;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public RepeatStatus execute(StepContribution contribution, ChunkContext chunkContext)
|
||||||
|
throws Exception {
|
||||||
|
|
||||||
|
log.info(
|
||||||
|
"Executing post-shapefile UPDATE for inferenceId={}, batchIds={}", inferenceId, batchIds);
|
||||||
|
|
||||||
|
List<Long> batchIdList =
|
||||||
|
List.of(batchIds.split(",")).stream().map(Long::parseLong).toList();
|
||||||
|
|
||||||
|
// TODO: 실행할 UPDATE SQL을 여기에 작성하세요.
|
||||||
|
// 예시:
|
||||||
|
// int updated = jdbcTemplate.update(
|
||||||
|
// "UPDATE some_table SET status = 'EXPORTED', inference_id = ? WHERE batch_id = ANY(?)",
|
||||||
|
// ps -> {
|
||||||
|
// ps.setString(1, inferenceId);
|
||||||
|
// ps.setArray(2, ps.getConnection().createArrayOf("bigint", batchIdList.toArray()));
|
||||||
|
// });
|
||||||
|
// log.info("Updated {} rows", updated);
|
||||||
|
|
||||||
|
log.info("Post-shapefile UPDATE completed");
|
||||||
|
|
||||||
|
return RepeatStatus.FINISHED;
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user