JSCODE Logo
블로그후기멘토진
회사명 : JSCODE대표 : 박재성사업자 등록번호 : 244-22-01557통신판매업 : 제 2023-인천미추홀-0381 호
학원 명칭 : 제이에스코드(JSCODE)원격학원학원설립ㆍ운영 등록번호 : 제6063호

서울특별시 구로구 경인로 20가길 11(오류동, 아델리아)

Copyright ⓒ 2025 JSCODE - 최상위 현업 개발자들의 프로그래밍 교육 All rights reserved.

이용약관개인정보처리방침
← 블로그 목록으로 돌아가기

[실습] Tasklet 인터페이스로 단일 배치 작업 처리하기

JSCODE 시니
JSCODE 시니
2026. 04. 04.
author
JSCODE 시니
category
Spring Batch
createdAt
Feb 7, 2026 01:11 AM
isPublic
isPublic
series
Spring Batch 입문: 3시간 만에 끝내는 대용량 처리의 기초
slug
implementing-simple-tasklet-batch
type
post
updatedAt
Apr 4, 2026 10:00

✅ 1. 코드 작

CafeJobTasklet.java
package com.system.batch; @Slf4j @Component public class CafeJobTasklet implements Tasklet { private int cakeCount = 0; private final int ORDER_TARGET = 10; @Override public @Nullable RepeatStatus execute(StepContribution contribution, ChunkContext chunkContext) throws Exception { cakeCount++; log.info("케이크를 만들고 있습니다. ({}/{})", cakeCount, ORDER_TARGET); if (cakeCount >= ORDER_TARGET){ log.info("목표한 모든 케이크를 만들었습니다. 가게를 오픈하세요!"); cakeCount = 0; // 재실행을 위한 초기화 return RepeatStatus.FINISHED; // 작업 완료 } return RepeatStatus.CONTINUABLE; // 계속해서 작업 } }
 
 
 

✅ 2. while문으로 한 번에 처리하면 안되는 이유

notion image
  • 100만건의 데이터를 처리하다가 99만건에서 에러가 난다면?
    • while문으로 하나로 묶어 작업하게 되면, 모든 데이터를 롤백해야함
    • 태스크릿의 execute메서드는 한번 수행할 때 마다 하나의 트랜잭션을 만들어냄.
    • 따라서, 문제된 데이터만 롤백 하면 된다.
 
author
category
Spring Batch
createdAt
Mar 5, 2026 10:56 PM
isPublic
isPublic
series
Spring Batch 입문: 3시간 만에 끝내는 대용량 처리의 기초
slug
type
series-footer
updatedAt
Apr 4, 2026 10:00
📎
이 글은 Spring Batch 입문 강의의 수업 자료 중 일부입니다.