인프런 커뮤니티 질문&답변

갓다귀갓장국님의 프로필 이미지
갓다귀갓장국

작성한 질문수

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

간단한 주문 조회 V2: 엔티티를 DTO로 변환

영상 11:00 ~ 11:30 내용 질문입니다.

해결된 질문

작성

·

189

2

OrderRepository에 직접 접근해서 findAll을 호출해서 DTO 객체를 만드는데요.

이메서드에는 @Transactional이 안붙어있어서 엔티티매니저가 메서드 호출이 완료되더라도 1차캐시가 끝나지않고 유지되는데 문제는  @Transactional를 붙일경우 메서드 호출이 끝나면 엔티티 매니저도 같이 종료시켜버리지만,

이 코드에서는 컨트롤러에서 엔티티 매니저를 close()를 명시적으로 호출하지 않는데 이럴경우 문제 없을까요? 

답변 1

7

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 갓다귀갓장국님

스프링과 JPA를 함께 사용하면, JPA가 영속성 컨텍스트를 관리해줍니다.

기본 동작은 트랜잭션이 시작할 때 영속성 컨텍스트가 생성되고, 트랜잭션이 종료될 때 영속성 컨텍스트도 함께 종료됩니다.

스프링이 이런 부분을 관리해주기 때문에 걱정하지 않으셔도 됩니다.

추가로 JPA는 트랜잭션 없이 읽기는 기능도 제공합니다. 이름 그대로 트랜잭션이 없어도 단순한 읽기는 가능합니다. 이 경우 영속성 컨텍스트는 데이터를 조회하자 마자 사라진다고 이해하시면 됩니다.

이런 메커니즘에 더해서 추가로 영향을 주는 것이 OSIV(OEIV)라는 것이 있는데요. 아마도 궁금해 하시는 부분이 바로 이것 때문에 그럴꺼에요^^ OSIV(OEIV)는 Open Session(EntityManager) In View라는 뜻인데요. 이게 마지막 퍼즐조각입니다.

스프링 부트는 기본으로 OSIV(OEIV)라는 것을 활성화시켜 두는데요. 이게 활성화 되어 있으면 API 호출 시작부터 ~ API 호출 종료까지 영속성 컨텍스트가 유지됩니다. 그래서 트랜잭션이 없는 컨트롤러에서도 지연로딩을 사용할 수 있는 것이지요. 이렇게 보면 그냥 좋아보이지만, 성능 관점에서 안좋은 포인트들이 많습니다. (그래서 안티 패턴으로 불리기도 합니다.)

OSIV에 대한 자세한 내용은 강의 마지막에 API 개발 고급에서 알려드립니다.

감사합니다.

갓다귀갓장국님의 프로필 이미지
갓다귀갓장국

작성한 질문수

질문하기