[실전! 스프링 부트와 JPA 활용 2 - API 개발과 성능 최적화] API 개발 고급(4): OSIV와 성능 최적화
·
Back-End/JPA
[작성일: 2023. 10. 06]  OSIV와 성능 최적화 Open Session In Viewspring.jpa.open-in-view : true 기본값 이 기본값을 뿌리면서 애플리케이션 시작 시점에 warm 로그를 남기는 이유가 있다.  OVIS 전략은 트랜잭션 시작처럼 최초 데이터베이스 커넥션 시작 시점부터 API 응답이 끝날 때까지 영속성 컨텍스트와 데이터베이스 커넥션을 유지한다.그래서 지금까지 View Template나 API 컨트롤러에서 지연 로딩이 가능했던 것이다.지연 로딩은 영속성 컨텍스트가 살아있어야 가능하고, 영속성 컨텍스트는 기본적으로 데이터베이스 커넥션을 유지해야 한다. 그런데 이 전략은 너무 오랜 시간동안 데이터베이스 커넥션 리소스를 사용하기 때문에 실시간 트래픽이 중요한 애플..
[실전! 스프링 부트와 JPA 활용 2 - API 개발과 성능 최적화] API 개발 고급(3): 컬렉션 조회 최적화(2)
·
Back-End/JPA
[작성일: 2023. 10. 05] 컬렉션 조회 최적화(2)주문 조회 V4: JPA에서 DTO 직접 조회@RestController@RequiredArgsConstructorpublic class OrderApiController { private final OrderRepository orderRepository; private final OrderQueryRepository orderQueryRepository; // ... 코드생략 @GetMapping("/api/v4/orders") public List ordersV4(){ return orderQueryRepository.findOrderQueryDtos(); }} @Datapublic class O..
[실전! 스프링 부트와 JPA 활용 2 - API 개발과 성능 최적화] API 개발 고급(3): 컬렉션 조회 최적화(1)
·
Back-End/JPA
[작성일: 2023. 10. 03] 컬렉션 조회 최적화(1)주문 조회 V1: 엔티티 직접 노출주문내역에서 추가로 주문한 상품 정보를 추가로 조회하려면 Order 기준으로 컬렉션인 OrderItem과 Item이 필요하다.지금은 OneToOne, ManyToOne 관계만 있다.이번에는 컬렉션인 일대다 관계(OneToMany)를 조회하고 최적화 하는 방법을 알아보자. @RestController@RequiredArgsConstructorpublic class OrderApiController { private final OrderRepository orderRepository; @GetMapping("/api/v1/orders") public List ordersV1() { Lis..
[실전! 스프링 부트와 JPA 활용 2 - API 개발과 성능 최적화] API 개발 기본
·
Back-End/JPA
[작성일: 2023. 09. 28]  회원 등록 API@RestController@RequiredArgsConstructorpublic class MemberApiController { private final MemberService memberService; @PostMapping("/api/v1/members") public CreateMemberResponse saveMemberV1(@RequestBody @Valid Member member) { Long id = memberService.join(member); return new CreateMemberResponse(id); } @Data @AllArgsConstructor sta..