BackEnd/SpringBoot 8

CircuitBreaker 로 예방하는 장애 전파(2)

이번 포스팅에서는 지난 포스팅에 이어 CircuitBreaker를 실제로 구현하는 것에 대해 알아보도록 하겠습니다. 📌CircuitBreaker를 지원하는 라이브러리의 종류 1. Netflix Hystrix Netflix 에서 개발한 라이브러리로 MSA 환경에서 서비스 간 통신이 원활하지 않을 경우 각 서비스가 장애 내성과 지연 내성을 갖게 하는 라이브러리이지만 현재는 deprecated 된 상태로 더 이상의 업데이트가 없으며 공식 문서에서도 Resilience4j 의 사용을 권장하고 있습니다. 2. Resilience4j Netflix Hystrix로부터 영감을 받아 개발된 Fault Tolerance 라이브러리 Java 전용으로 개발된 라이브러리 입니다. 📌CircuitBreaker의 코어 모듈 Re..

BackEnd/SpringBoot 2023.12.12

CircuitBreaker 로 예방하는 장애 전파(1)

📌 들어가며 소프트웨어는 모두 실패한다 - 버너 보겔스(아마존 부사장) 아무리 열심히 설계하여 개발하고 QA를 진행한다 하더라도 대고객 시스템의 경우 혹은 대고객이 아니더라도 예상치 못한 장애를 마주하는 경우가 발생합니다. 여러 개의 작은 독립적인 마이크로서비스로 분할하는 아키텍처 패턴이 많아지는 요즘, 단일 서브 도메인의 장애가 전체 시스템에 영향을 줄 수 있어 예상치 못한 장애 상황이 발생할 수 있습니다. 이렇게만 보면 MSA 아키텍처로 설계하는 것 자체가 잘못된 것은 아닐까 하는 생각이 들 수 있습니다. 하지만 이는 '완벽한 시스템을 만들기보다, 실패에 유연하고 빠르게 대응 가능한 시스템을 설계해야 한다.' 라는 의미로 해석할 수도 있습니다. 따라서 MSA 환경에서는 단일 서브 도메인(마이크로서비스..

BackEnd/SpringBoot 2023.12.10

Spring Transaction 에 대한 이해

📌 들어가며 코드리뷰를 진행하다 보면 항상 나오는 얘기 중 하나가 바로 '트랜잭션 관리를 어떻게 할것인가' 에 대한 내용입니다. 그만큼 Exception이 발생했을 때 어떻게 할 것인가에 대한 내용이 중요한 만큼 이에 대한 대처 중 하나인 Transaction에 대해 정리해 보도록 하겠습니다. 📌 Transaction 의 정의 트랜잭션은 데이터베이스의 상태를 변경하는 작업 또는 한번에 수행되어야 하는 연산들을 뜻합니다. 즉, 병행 제어 시 처리되는 작업의 논리적 단위입니다. Transaction은 하나의 흐름으로 하나의 실행이 성공하거나 실패하면 모든 연산들을 동일하게 처리합니다. A, B, C의 연산을 한 묶음이라고 할 때 A는 정상 작동 됐지만, B가 실패한다면 A의 작업 이력도 이전으로 돌립니다. ..

BackEnd/SpringBoot 2023.09.20

[Spring] 어노테이션의 정의와 동작원리

📌 들어가며 SpringBoot를 이용해 개발을 하다보면 정말 많이 사용하게 되는 것 중 하나가 어노테이션입니다. 종류도 매우 다양하며(@RestController, @Component.. 등) Personal 어노테이션을 만들 수도 있습니다. 오늘은 이러한 Spring에서 어노테이션의 정의와 동작원리에 대해서 알아보도록 하겠습니다. 📌 Annotation 의 정의 어노테이션에 대한 정의를 자바 공식 문서에서 찾아보면 https://docs.oracle.com/javase/tutorial/java/annotations/ Lesson: Annotations (The Java™ Tutorials > Learning the Java Language) The Java Tutorials have been writ..

BackEnd/SpringBoot 2023.09.18

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

📌 들어가며 백엔드 개발을 할 때 가장 신경쓰게 되는 것은 아무래도 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

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