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

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

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

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

[실습] 배치 Listener 적용하기

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

✅ 1. 배치 시작과, 배치끝을 알려주는 리스너 작성

JobLoggerListener.java
package com.batch.settlement.listener; @Slf4j @Component public class JobLoggerListener { private static final String START_MESSAGE = "'{}' 배치를 시작합니다!"; private static final String END_MESSAGE = "'{}' 배치가 종료되었습니다. (상태 : {})"; @BeforeJob public void beforeJob(JobExecution jobExecution) { log.info("================================="); log.info(START_MESSAGE, jobExecution.getJobInstance().getJobName()); log.info("================================="); } @AfterJob public void afterJob(JobExecution jobExecution){ long duration = Duration.between( jobExecution.getStartTime(), jobExecution.getEndTime() ).toMillis(); log.info("================================="); log.info(END_MESSAGE, jobExecution.getJobInstance().getJobName(), jobExecution.getStatus()); log.info("총 소요 시간: {} ms", duration); log.info("================================="); if(jobExecution.getStatus() == BatchStatus.FAILED){ log.error("배치가 실패했습니다!"); } } }
 
 

✅ 2. 리스너 등록하기

SettlementJobConfig.java
private final JobLoggerListener jobLoggerListener; @Bean public Job settlementJob(){ return new JobBuilder("settlementJob", jobRepository) .listener(jobLoggerListener) // 리스너 추가! .start(settlementStep()) .build(); }
 
 

✅ 3. 배치 실행 및 동작 확인

notion image
 
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 입문 강의의 수업 자료 중 일부입니다.