• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

엔티티매니저는 스레드별로 다시 생성되나요?

23.07.27 04:49 작성 조회수 481

0

스크린샷 2023-07-27 오전 2.11.17.png스크린샷 2023-07-27 오전 2.41.33.png

 

영한님 JPA 책에서 아래 그림을 보면 스레드가 하나이고 두개의 레포지토리를 사용할때 두개의 엔티티매니저가 하나의 영속성컨텍스트를 사용한다고 나와있습니다. 하지만 테스트 결과(레포지토리에 각각의 엔티티매니저가 있지만 SharedEntityManagerCreator를 통해서(?) 하나의 엔티티매니저를 사용하는걸 확인 했습니다(하나의 SessionImpl을 사용하고 있었으며 내부에 영속성 컨텍스트도 공유함)

제가 이해한바가 맞는지 봐주시면 감사하겠습니다.

  1. 엔티티매니저는 Bean으로 등록되지 않는다.

  2. 엔티티매니저프록시객체에 메서드를 호출하면 현재 트랜잭션에서 사용되고 있는 엔티티매니저가 있는지 확인후 없다면 팩토리를 통해 엔티티매니저를 생성하고 있다면 재사용한다.

  3. 엔티티매니저팩토리(인터페이스)는 직접 빈으로 등록되지 않고 LocalContainerEntityManagerFactoryBean 가 빈으로 등록되고 내부 필드에 EntityManagerFactory를 가지고 있고 다른곳에서 생성하지 않기때문에 논리적으로 싱글톤이다 라고 할 수 있다 라고 이해했습니다.

     

질문

  1. 이해한 내용에서 3번이 맞다면 LocalContainerEntityManagerFactoryBean 에는 프록시 팩토리와 네이티브 팩토리가 있는데 왜 나눠서 인스턴스 변수로 갖고있는걸까요?

  2. EntityManagerFactory를 @Autowired로 주입받을때

    LocalContainerEntityManagerFactoryBean 가 프록시 엔티티매니저팩토리를 만들어서 넣어주는걸까요?

  3. ㅈㄷ.png사진에서 SimpleJpaRepository에 em은 디버깅에서 위에 사진처럼 나오고 있는데 이유는 LocalContainerEntityManagerFactoryBean에서 팩토리를 통해 프록시 객체를 생성해주기 때문인가요?

  4. 엔티티매니저프록시에서 메소드가 호출되면 리플랙션으로 SharedEntityManagerCreator.invoke 메소드가 호출되서 실제 엔티티매니저를 실행한다고 이해하면 될까요?

  5. LocalContainerEntityManagerFactoryBean 의 역할을 모르겠습니다.ㅠㅠ 팩토리를 논리적 싱글톤으로 관리하기 위한 객체일까요?

너무 궁금해서 이 새벽까지 디버깅하다보니 질문이 많습니다 ㅠㅠ 답변주시면 감사하겠습니다!

답변 2

·

답변을 작성해보세요.

0

안녕하세요. YOGURT님

다음을 참고해주세요.

https://www.inflearn.com/questions/158967

감사합니다.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2023.07.29

안녕하세요, 인프런 AI 인턴이에요. 엔티티 매니저에 대해 질문해주셔서 감사합니다.

일반적으로 JPA에서 엔티티 매니저는 스레드별로 다시 생성되지 않습니다. 스레드 내에서 동일한 엔티티 매니저를 사용하게 됩니다. 이는 엔티티 매니저가 스레드간에 공유되지 않고 스레드 내에서만 사용되기 때문입니다.

예를 들어, 각각의 레포지토리에서 엔티티 매니저를 사용하더라도, 실제로는 같은 영속성 컨텍스트를 공유하는 것이 일반적입니다. 이는 JPA의 영속성 컨텍스트가 스레드 내에 유지되어 동일한 트랜잭션 내에서 엔티티를 공유하기 때문입니다.

그러나 이러한 동작 방식은 JPA 구현체인 하이버네이트를 포함한 다른 구현체에서 동작 방식을 변경할 수 있습니다. 따라서 JPA 구현체에 따라서 엔티티 매니저의 동작 방식이 조금씩 다를 수 있습니다.

그렇기 때문에 구체적인 상황에서 어떤 JPA 구현체를 사용하고 있는지에 따라 엔티티 매니저의 동작 방식이 달라질 수 있습니다. 이 점을 고려하여 애플리케이션을 설계해야 합니다.

더 자세한 내용은 JPA 구현체의 공식 문서를 참고하시는 것이 도움이 될 것입니다. 감사합니다.