springboot 7

스프링 부트 로컬 캐시 적용하기

📌 들어가며 백엔드 개발을 할 때 가장 신경쓰게 되는 것은 아무래도 API의 성능일 것입니다. 많은 트래픽을 받아도 안정적인 속도로 동일한 결과를 사용자에게 제공해 주어야 하기 때문입니다. 이번 포스팅에서는 이러한 API의 성능을 높일 때 사용되는 방법중 하나인 캐시를 적용하는 방법을 알아보고자 합니다. 캐시를 적용하기 위해 Redis를 사용하기도 하는데요 해당 포스팅에서는 스프링부트의 자체 캐시(로컬 캐시)를 사용해 보도록 하겠습니다. 📌 캐시란? 캐시는 자주 사용하는 데이터를 저장해두고 재활용하는 기술을 뜻합니다. 일반적으로 캐시는 일시적인 특징이 있는 데이터 집합을 고속 데이터 스토리지 저장합니다. 따라서 이후에 해당 데이터에 대한 동일한 요청이 있을 경우, 데이터의 원본 스토리지 위치로 액세스할 ..

BackEnd/SpringBoot 2023.06.25

Feign Client 를 활용하여 외부통신 연동하기

📌 들어가며 백엔드 API 개발을 하다보면 외부 서비스와 연동해야 하는 일이 많이 생깁니다. 특히 현재 주문/결제 도메인팀에 있다보니 더더욱 비즈니스 로직에서 외부통신을 해야하는 경우가 많이 생기는 것 같습니다. 이번 포스팅에서는 외부통신을 도와주는 많은 라이브러리들(HttpClient, WebClient) 중 Feign Client 에 대해 알아보고자 합니다. 📌 Feign Client Feign Client란 Netflix에서 개발한 Http Client입니다. (HttpClient는 Http 요청을 간편하게 만들어서 보낼 수 있도록 돕는 객체) 처음에는 Netflix에서 자체적으로 개발을 진행(Spring Cloud Netflix Feign)했지만 현재는 오픈소스 프로젝트인 OpenFeign으로 전..

BackEnd/SpringBoot 2023.04.22

백엔드 아키텍처 개요(2) - DIP

지난 글에서 가장 기본적인 계층 구조의 아키텍처 구성에 대해 알아보았습니다. 이번 글에서는 그러한 계층 구조 아키텍처를 사용했을 때의 문제점과 이를 해결하기 위한 DIP(Dependency Inversion Principle) 의존성 역전 원칙을 알아보도록 하겠습니다. 예를 들어 어떠한 도메인의 가격 계산 규칙 기능이 있습니다. 할인 금액 계산 로직이 복잡해지게 되면 객체 지향으로 로직을 구현하는 것보다 룰 엔진을 사용하는 것이 더 알맞을 때가 있습니다. 다음의 예시 코드는 Drools라는 룰 엔진을 사용해서 로직을 수행하는 인프라스트럭처 영역의 코드입니다. public class DroolsRulerEngine { private KieContainer kContainer; public DroolsRul..

Architecture 2023.01.22

String 형태가 아닌 LocalDateTime그대로 받아보자!

Spring을 사용하여 개발 할 경우 Controller에서 요청 과 응답을 주고 받을 때 DTO에서 LocalDate와 LocalDateTime을 사용할 경우가 종종 있습니다. 이때 직렬화를 하지 못해 String으로 받은 후 서비스 레이어에서 혹은 DB에 저장하기 직전에 변환하는 경우가 있습니다. Spring에선 굳이 이럴 필요가 없으니 아래 내용을 토대로 번거로운 과정을 생략해보면 좋을 것 같습니다. 우선적으로 정답을 말씀드리면 @JsonFormat 어노테이션과 @DateTimeForamt을 사용하면 가능합니다. 1. RequestParameter 1-1. @ModelAttribute Controller 코드 @GetMapping("/get") public String get(GetModel get..

BackEnd/SpringBoot 2023.01.01

SpringBoot @Converter @Convert 데이터 처리 시 활용

코딩을 하다보면 java 에서는 CardStatus 와 같은 Card의 현 상태를 Enum을 사용해서 값(ACTIVE, USE, PAUSE)을 다루고 싶고 데이터베이스에는 해당 Status에 따른 표현 값("A", "U", "P")을 저장하고 싶은 경우가 있습니다. java에서의 코딩할때의 표현 값과 DB에 실제 저장되는 값이 다르게 하는 것입니다. public enum CardStatus { ACTIVE("A"), // 발행 USE("U"), // 사용 PAUSE("P"); //사용 정지 private final String value; @JsonValue public String getValue() { return value; } CardStatus(String value) { this.value =..

BackEnd/SpringBoot 2022.12.11

[JPA] 영속성 연관관계 전이 CASCADE 란?

JPA를 공부하면서 항상 헷갈렸던 부분이라 명확하게 정리를 해보고 넘어가려 합니다. CASCADE - 영속성 연관관계의 전이를 의미합니다. - 부모 엔티티에서 자식 엔티티로 상태를 전이하는 것입니다. ex. 부모 엔티티 저장할 때 자식 엔티티도 함께 저장, 게시글과 첨부파일 - Parent와 Child가 라이프사이클이 동일할 때, Child를 소유하는 Parent가 하나일 때 사용하는 것이 좋습니다. Entity의 상태 Transient : JPA가 모르는 상태 (단순 객체 생성) Persistent : JPA가 관리중인 상태 (1차 캐시, Dirty Checking, Write Behind, ...) Detached : JPA가 더이상 관리하지 않는 상태 Removed : JPA가 관리하긴 하지만 삭제..

BackEnd/JPA 2022.11.13

JPA의 Dirty Checking이란?

Jpa를 활용하여 백엔드 개발을 하다보면 'JPA 영속성 컨텍스트' 혹은 '더티 체킹'이란 말을 종종 들을 수 있습니다. 실제로 얼마전에 회사에서 코드리뷰를 진행하는데 어떤 팀원 분께서 다음과 같이 말씀하셨다. 제가 알기로 JPA는 더티 체킹이라는 걸 해서 변경사항을 감지해 자동으로 update를 해주는 걸로 알고 있는데 왜 한번 더 save를 해줬나요? 이유가 있어요? 그 때 나는 물론 명확하게 답변을 드리지 못했다... 아..? 네..! 그러면 한번 더 save 하지 않고 트랜잭션을 마무리 하도록 하겠습니다. 라고 대충 얼버무렸던 기억이.... 그래서 오늘은 이 Dirty Checking 이라는 것의 개념을 한번 짚고 넘어가려고 합니다. 다음에는 명확히 답변드릴 수 있도록...! 예를 들어 다음과 같..

BackEnd/JPA 2022.11.05