본문 바로가기

개발35

[Pattern] 싱글톤 패턴 정리 목적 단 하나의 유일한 객체를 만들기 위한 디자인 패턴 클래스의 인스턴스를 오직 하나만 만들어서 글로벌하게 접근할 수 있도록 한다. 메모리 절약을 위해 인스턴스가 필요할 때 똑같은 인스턴스를 만들지 않고 기존의 인스턴스를 가져와 활용하는 기법 대부분 리소스를 많이 차지하는 역할을 하는 무거운 클래스를 대상으로 한다. ex) 데이터베이스 연결 모듈, 디스크 연결, 네트워크 통신, DBCP 커넥션풀, 스레드풀, 캐시, 로그 기록 객체 자바로 싱글톤 패턴 구현 생성자를 private으로 설정해서 외부에서 인스턴스로 만들 수 없게 만드는 것이 중요하다. 1. Lazy initialization public class Singleton { private static Singleton instance; privat.. 2023. 6. 25.
[Spring Cloud] 마이크로서비스간 통신 (RestTemplate vs FeignClient) 마이크로서비스 간 통신모놀리식 애플리케이션은 단순하게 메서드를 호출함으로 써, 요청에 대해 응답을 처리할 수 있었다.하지만, 분산 시스템에서 각각의 독립적인 Micro Service가 서로 통신하는 작업이 필요하다.마이크로서비스 간 통신은 주로 HTTP기반 Restful API를 사용하여 이루어진다. RestTemplate vs FeignClientRestTemplateSpring Framework에서 제공하는 HTTP 클라이언트다른 서비스로의 HTTP 요청을 수행하고 응답을 받아올 수 있다. 장단점장점다양한 HTTP 메서드를 지원하고, 요청을 다양한 방식으로 커스터마이즈 할 수 있다.오랜 기간 동안 사용되어 왔기 때문에, 많은 개발자들에게 익숙하다.많은 커스터마이즈를 제공해 복잡한 통신 시나리오를 다룰.. 2023. 6. 22.
[Spring Cloud] Config Server 설정 정보의 암호화 처리 Spring Cloud Config 공식 문서에서 Features를 보면, Encrypt와 Decrypt를 지원한다.각 마이크로 서비스에서 중요한 설정 정보는 보안에 민감한 정보들이 많다.ex) 데이터베이스 암호, API 키, JWT의 Secret Key와 같은 사용자 인증 정보 등따라서 설정 정보에 보안에 민감한 정보를 저장할 때는 암호화를 하여 저장하는 것이 매우 중요하다.Spring Cloud Config의 Encrypt와 Decrypt를 사용하여 설정 정보를 안전하게 저장하는 방법에 대해서 알아보자.  대칭키 암호화(symmetric) & 비대칭키 암호화(asymmetric)대칭키 암호화암호화와 복호화에 동일한 키를 사용하는 방식주요 알고리즘으로는 DES(Data Encryption Standar.. 2023. 6. 20.
[Spring Cloud] Config Server 구축하기 (busrefresh 하기) Spring Cloud Config Server분산 시스템 환경에서 서버, 클라이언트 구성에 필요한 설정 정보를 외부 시스템에서 관리하는 서버외부에서 모든 환경에 대한 정보들을 관리해주는 중앙 서버기존에는 각 Micro Service가 설정 정보 파일(application.yml)를 관리하여, 해당 파일이 변경되면 해당 서버를 다시 빌드하고 배포해야하는 번거로움이 있었다. Config Server의 장단점장점여러 서버의 설정 파일을 중앙 서버에서 관리할 수 있다.변경 사항이 있을 때 모든 Micro Service에 대해 일관된 업데이트를 적용할 수 있어, 중복 설정을 줄이고 유지 보수를 간소화할 수 있다.Mirco Service가 재배포 하지 않고 설정 파일의 변경사항을 반영할 수 있다.여러 환경(개발,.. 2023. 6. 19.
[Spring Cloud] Spring Cloud Gateway 구축하기 Spring Cloud Gateway 👍🏻스프링 기반 API Gateway마이크로서비스 아키텍처에서 라우팅, 로드 밸런싱, 필터링 등 역할을 수행Spring 5, Project Reactor를 기반으로 구축되어 비동기 및 논블로킹 기능 지원Netty 서버를 사용하여 높은 성능을 제공 Gradle 의존성 추가implementation 'org.springframework.cloud:spring-cloud-starter-gateway'implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-client'API Gateway 서버를 Eureka Server(서비스 디스커버리)에 등록하기 위해 eureka-client 의존성 .. 2023. 6. 12.
[Spring Cloud] Client Side Load Balancer & API Gateway 개념 정리 Client Side Load BalancerNetflix RibbonClient Side Load Balancer : 클라이언트에 탑재되어 있는 Load BalancerHardware 가 필요 없이 Software 로만 가능 IP와 PORT가 아닌 서비스 이름으로 호출 (서비스 디스커버리 기능 지원)비동기 처리를 지원하지 않고, 동기적인 방식으로 요청을 전송한 후 해당 요청에 대한 응답을 기다리는 동안 블로킹된다.Blocking방식의 HttpClient인 RestTemplate만 지원Spring Boot 2.4부터 maintenance 상태대안책 : Spring Cloud LoadBalancer Spring Cloud LoadBalancer 👍🏻Client Side Load Balancer : 클라.. 2023. 6. 11.