spring boot에서 @Async를 사용하여 비동기식 호출 작업 수행
'비동기 호출'에 대응하는 것은'동기 호출'이다. 동기 호출은 프로그램이 정의된 순서에 따라 순서대로 실행하는 것을 가리키며 모든 프로그램은 이전 프로그램이 실행된 후에야 실행할 수 있다.비동기 호출은 프로그램이 순서대로 실행될 때, 비동기 호출된 문장이 결과를 되돌려 주기를 기다리지 않고 뒤에 있는 프로그램을 실행하는 것을 말한다.
동기화 호출
다음은 간단한 예제를 통해 동기화 호출이 무엇인지 직관적으로 이해합니다.
Task 클래스를 정의하고 세 개의 처리 함수를 생성하여 각각 세 개의 작업 수행 동작을 시뮬레이션하고 작업 소모 시간을 무작위로 추출(10초 이내)
package com.kfit.task;
import java.util.Random;
import org.springframework.stereotype.Component;
/**
* 3
* @author Angel(QQ:412887952)
* @version v.0.1
*/
@Component
publicclass Task1 {
// .
publicstatic Random random =new Random();
// ;
publicvoid doTaskOne() throws Exception {
System.out.println(" ");
longstart = System.currentTimeMillis();
Thread.sleep(random.nextInt(10000));
longend = System.currentTimeMillis();
System.out.println(" , :" + (end - start) + " ");
}
// ;
publicvoid doTaskTwo() throws Exception {
System.out.println(" ");
longstart = System.currentTimeMillis();
Thread.sleep(random.nextInt(10000));
longend = System.currentTimeMillis();
System.out.println(" , :" + (end - start) + " ");
}
// 3;
publicvoid doTaskThree() throws Exception {
System.out.println(" ");
longstart = System.currentTimeMillis();
Thread.sleep(random.nextInt(10000));
longend = System.currentTimeMillis();
System.out.println(" , :" + (end - start) + " ");
}
}
액세스 방법 작성:
// task1.
@RequestMapping("/task1")
public String task1() throws Exception{
task1.doTaskOne();
task1.doTaskTwo();
task1.doTaskThree();
return"task1";
}
실행하면 다음과 같은 출력을 볼 수 있습니다.미션 1 시작하겠습니다.
작업 완료 1, 소요 시간: 4156ms
미션 2 시작하겠습니다.
작업 완료 2, 소요 시간: 557ms
미션 3 시작하겠습니다.
작업 완료 3, 소요 시간: 6171ms
비동기식 호출
상술한 동기화 호출은 세 가지 임무를 순조롭게 집행했지만 집행 시간이 비교적 긴 것을 볼 수 있다. 만약에 이 세 가지 임무 자체에 의존 관계가 존재하지 않고 병행 집행할 수 있다면 동기화 호출은 집행 효율에 있어서 비교적 좋지 않기 때문에 이보조를 통해 병행 집행하는 것을 고려할 수 있다.
Spring Boot에서 @Async 메모를 사용하면 기존의 동기화 함수를 비동기화 함수로 간단하게 변경할 수 있습니다. Task 클래스는 다음과 같은 모드로 변경됩니다.
package com.kfit.task;
import java.util.Random;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;
/**
* 3
* @author Angel(QQ:412887952)
* @version v.0.1
*/
@Component
publicclass Task2 {
// .
publicstatic Random random =new Random();
// ;
@Async
publicvoid doTaskOne() throws Exception {
System.out.println(" ");
longstart = System.currentTimeMillis();
Thread.sleep(random.nextInt(10000));
longend = System.currentTimeMillis();
System.out.println(" , :" + (end - start) + " ");
}
// ;
@Async
publicvoid doTaskTwo() throws Exception {
System.out.println(" ");
longstart = System.currentTimeMillis();
Thread.sleep(random.nextInt(10000));
longend = System.currentTimeMillis();
System.out.println(" , :" + (end - start) + " ");
}
// 3;
@Async
publicvoid doTaskThree() throws Exception {
System.out.println(" ");
longstart = System.currentTimeMillis();
Thread.sleep(random.nextInt(10000));
longend = System.currentTimeMillis();
System.out.println(" , :" + (end - start) + " ");
}
}
@Async 메모가 유효하도록 하려면 Spring Boot의 주 프로그램에서 @EnableAsync를 다음과 같이 구성해야 합니다.
@SpringBootApplication
@EnableAsync
publicclass App {
// …
}
테스트 메서드 작성:
// task2.
@RequestMapping("/task2")
public String task2() throws Exception{
task2.doTaskOne();
task2.doTaskTwo();
task2.doTaskThree();
return"task2";
}
단원 테스트를 반복해서 수행할 수 있습니다. 예를 들어 다음과 같은 다양한 결과를 얻을 수 있습니다.미션 1 시작하겠습니다.
미션 2 시작하겠습니다.
미션 3 시작하겠습니다.
작업 완료 3, 소요 시간: 57ms
작업 완료 2, 소요 시간: 3621ms
작업 완료 1, 소요 시간: 7419ms
이상은 본문의 전체 내용입니다. 여러분의 학습에 도움이 되고 저희를 많이 응원해 주십시오.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
thymeleaf로 HTML 페이지를 동적으로 만듭니다 (spring + gradle)지난번에는 에서 화면에 HTML을 표시했습니다. 이번에는 화면을 동적으로 움직여보고 싶기 때문에 입력한 문자를 화면에 표시시키고 싶습니다. 초보자의 비망록이므로 이상한 점 등 있으면 지적 받을 수 있으면 기쁩니다! ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.