JPA2 - API 개발 고급_실무 필수 최적화

young·2023년 5월 29일
0

Spring Boot

목록 보기
17/19
post-thumbnail

🖇️OSIV와 성능 최적화

Open Session In View : 하이버네이트

Opne EntityManager In View : JPA

OSIV 전략

: 영속성 컨텍스트를 뷰까지 열어두는 기능

  • View Template이나 API 컨트롤러에서 지연 로딩이 가능함

💡 트랜잭션이 처음 발생할 때 JPA가 데이터베이스 커넥션을 가져온다.

트랜잭션 시작처럼 최초 데이터베이스 커넥션 시작 시점부터 API 응답이 끝날 때까지 영속성 컨텍스트와 데이터베이스 커넥션을 유지한다.
그렇기 때문에 컨트롤러 단에서 최종적으로 Response를 보낼 때까지 살아있고, 컨트롤러에서 지연 로딩이 가능하다!

🚨 오랜 시간동안 데이터베이스 커넥션 리소스를 사용하기 때문에 실시간 트래픽이 중요한 어플리케이션에서는 커넥션이 모자랄 수 있음 = 장애 발생

spring.jpa.open-in-view : true 기본값

OSIV 종료

  1. 트랜잭션 종료 시 영속성 컨텍스트 닫음
  2. 데이터 커넥션 반환
    = 커넥션 리소스 낭비 X
  • 모든 지연로딩을 트랜잭션 안에서 처리(코드를 모두 트랜잭션 안으로)
  • view template에서 지연 로딩 동작 X

💡결론적으로 트랜잭션이 끝나기 전에 지연 로딩을 강제로 호출해 두어야 한다.

spring.jpa.open-in-view : false OSIV 종료

Command와 Query 분리

OrderService

  • OrderService: 핵심 비즈니스 로직
  • OrderQueryService: 화면이나 API에 맞춘 서비스 (주로 읽기 전용 트랜잭션 사용)

📌 보통 서비스 계층에서 트랜잭션을 유지한다. 두 서비스 모두 트랜잭션을 유지하면서 지연 로딩을 사용할 수 있다.

📌 참고 > 고객 서비스의 실시간 API는 OSIV를 끄고, ADMIN 처럼 커넥션을 많이 사용하지 않는 곳에서는 OSIV를 켠다.

profile
ฅʕ•̫͡•ʔฅ

0개의 댓글