작성
·
73
0
현재 버전에서는 YML에서 names로 job을 여러개 등록하는게 불가능한데
최신 버전 기준으로 JOB을 여러개 설정할 수 없을까요?
답변 2
0
yml 에서는 가능하지 않는 걸로 압니다
@Component
@RequiredArgsConstructor
public class MultiJobLauncher implements ApplicationRunner {
private final JobLauncher jobLauncher;
private final Job jobA;
private final Job jobB;
@Override
public void run(ApplicationArguments args) throws Exception {
JobParameters paramsA = new JobParametersBuilder()
.addLong("time", System.currentTimeMillis())
.toJobParameters();
jobLauncher.run(jobA, paramsA);
JobParameters paramsB = new JobParametersBuilder()
.addLong("time", System.currentTimeMillis() + 1)
.toJobParameters();
jobLauncher.run(jobB, paramsB);
}
}
예를 들어 위 예제처럼 할 수는 있습니다.
기본적으로 Spring Batch는 기본적으로 "한 번에 하나의 Job만 실행"이 원칙입니다
참고 바랍니다
0
안녕하세요, 인프런 AI 인턴입니다. 김은준님!
스프링 배치에서 여러 개의 Job을 설정하는 방법에 대해 궁금해 하셨군요. 스프링 배치에서 여러 Job을 구성하고 실행하는 것은 일반적인 요구사항 중 하나이며, 이를 효과적으로 관리하기 위해 몇 가지 방법이 존재합니다.
여러 개의 Job 정의: 각 Job을 독립적으로 @Bean으로 구성하고, 필요한 Step들로 각각의 Job을 정의할 수 있습니다. 이러한 Job들은 필요에 따라 특정 조건이나 일정에 따라 실행될 수 있습니다.
JobLauncherApplicationRunner 사용: 스프링 부트를 사용한다면 JobLauncherApplicationRunner
를 활용해 여러 Job을 실행할 수 있습니다. 기본적으로 이 클래스는 실행 가능한 Job을 자동으로 찾아 실행합니다. 만약 특정 Job만 실행하고 싶다면, 특정 Job 이름을 명령줄 매개변수로 입력하여 명시적으로 실행할 수도 있습니다.
다양한 방법으로 실행 관리: Spring Batch의 다양한 설정 및 프로그래밍 방식으로 여러 Job을 기동하거나 특정 Job을 선택적으로 실행하는 방법도 가능합니다. 이를 위해서는 커맨드 라인 매개변수나 JobParameter 등을 활용합니다.
Jobs를 YML 파일을 통해 여러 개 정의하는 것은 일반적으로 직접적인 방법으로는 제공되지 않지만, 다양한 설정 파일과 프로그래밍 방식을 통해 우회할 수 있습니다.
추가적인 설정 및 예제 코드가 필요한 경우, 아래의 질문과 답변을 참고하시면 도움이 될 것입니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.