inflearn logo
강의

講義

知識共有

本当! Spring BootとJPAの活用1 - Webアプリケーション開発

プロジェクト作成

애플리케이션이 2번실행?됩니다.

解決済みの質問

2038

seungbinkimdev2225

投稿した質問数 18

0

롬복 테스트를위해서 강의영상처럼 똑같이  작성하였는데, 실행됬을 때 콘솔을 보면 data = hello가 2번 출력됩니다.

코드

콘솔

밑에 아무런 출력이나 넣고 다시 해보면 그 출력까지도 2번출력되네요. 마치 메인메서드 2번실행되는것처럼 나옵니다.

웹앱 JPA java spring-boot spring

回答 3

1

seungbinkimdev2225

자세한 설명 감사합니다.!

1

yh

안녕하세요. 승빈님

확인을 해보니 spring-boot-devtools가 포함되어 있네요^^

다음과 같이 코드를 실행해보면 명확하게 알 수 있습니다.

private static Logger logger = LoggerFactory.getLogger(JpashopApplication.class);

public static void main(String[] args) {
logger.info("hello!");
SpringApplication.run(JpashopApplication.class, args);
}

출력결과

15:35:43.408 [main] INFO jpabook.jpashop.JpashopApplication - hello!

15:35:43.547 [restartedMain] INFO jpabook.jpashop.JpashopApplication - hello!

원래는 JVM이 실행되면서 main 쓰레드에서 스프링을 실행해야 하는데, devtools가 포함되어 있으면 JVM이 실행되고, main을 호출하면서 main 쓰레드가 실행은 됩니다. 그런데 스프링은 main 쓰레드가 아닌 restartedMain이라는 쓰레드에서 실행됩니다. 이 과정에서 restartedMain 쓰레드에서 스프링 컨테이너를 실행하기 위해서 main 메서드를 한번 더 호출합니다. 참고로 이때는 main쓰레드에서 스프링 컨테이너를 실행하지는 않습니다.

devtools는 코드에 변화가 있으면 JVM은 그대로 유지한채 스프링 컨테이너만 다시 실행합니다(인텔리J의 경우 build-> recompile 실행). 그래서 자바 JVM을 실행하는 시간을 줄일 수 있습니다. 결과적으로 스프링을 실행하는 시간만 추가됩니다.

이런 메커니즘을 정상 수행하기 위해서 main 쓰레드가 아닌 별도의 쓰레드에서 dev-tools가 스프링을 실행하게 됩니다.

감사합니다.

1

yh

안녕하세요. 승빈님

저도 정확한 이유를 모르겠네요. 전체 프로젝트를 압축해서 올려주세요.

감사합니다.

sdk 설정 오류

0

45

2

오탈자 - @Transactional

0

53

1

src/test/resources 테스트 경로 문제

0

49

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

62

1

MemberRepositoryTest 실행오류

0

74

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

182

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

137

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

50

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

71

1

기본 생성자

0

59

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

100

1

멤버서비스테스트 부분에서 막힙니다.

0

163

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

115

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

117

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

110

1

24분 27초 연관관계 편의 메서드 위치

0

112

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

106

2

빌드 툴, Gradle

0

57

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

73

2

Repository에서 EntityManager 주입 방식 차이

0

87

1

롬복과 사용자 정의 setter 메서드

0

70

1

주문 목록 조회 fetch join 질문드립니다

0

80

1

dirty checking 질문드립니다.

0

80

1

동시성 관련 질문입니다

0

72

1