Spring Cloud Netflix Eureka Service Discovery 마이크로서비스의 정보(위치 등)을 등록할 수 있음 외부의 요청이나 서비스가 마이크로서비스의 정보를 검색하기 위해 사용됨 이게 Eureka임 Eureka의 구성요소 Service Discovery : 외부에서 마이크로서비스를 찾아주는 기능 Service Registry : 각각의 서비스가 자신의 위치 정보를 특정 서버에 등록하는 작업 Eureka Service Discovery - 프로젝트 생성 Maven으로 진행 강의와 다르게 버전은 현재에 맞게 선택했다. Dependencies 등록 Spring Could Discovery > Eureka Server 선택 Spring Boot 버전도 현재에 맞게 선택했다. (다른 프로젝..
공부/MSA
12Factors +3 https://12factor.net/ Cloud Native Application 개발 하거나 서비스를 운영할 때 사용되는 항목들 BASE CODE 자체 레퍼 지토리에 저장된 각 마이크로 서비스에 대한 단일 코드 베이스, 버전을 관리하기 위한 목적이고 형상관리를 위해 코드를 한 곳에서 배포하기 위한 목적, 코드의 통일적 관리 DEPENDENCY ISOLATION(종속성) 마이크로서비스는 자체 종속성을 가지고 패키지 되어 있다. 전체 시스템에 영향을 주지 않고 변경되 고 수정 될 수 있어야 한다. CONFIGRATIONS(구성정보) 시스템 내부가 아닌 시스템 코드 외부에서 구성관리 도구를 통해서 마이크로서비스에 필요한 작업들을 지원 하는 것. 동일한 배포가 올바르게 구성된 환경에 ..
클라우드 네이티브 아키텍처에 의해 설계되고 구현되는 어플리케이션을 클라우드 네이티브 어플리케이션(Cloud Native Application)이다. 클라우드 네이티브 어플리케이션(Cloud Native Application)은 아키텍처의 특징이나 안티프레자일와 같은 특징을 가지고 다음과 같은 형태로 구현된다. 클라우드 네이티브 어플리케이션(Cloud Native Application) 특징 1. MicroServices 2. CI/CD CI(Continuous Integration, 지속적인 통합) 통합 서버, 소스 관리(SCM), 빌드 도구, 테스트 도구 ex) Jenkins, Team CI, Travis CI CD(지속적인 배포) CD에는 두 가지 의미가 포함되어 있다. 패키지화 된 형태의 결과물을 ..
기존의 로컬 환경이나 사내에서 구축하고 운영하였던 시스템을 클라우드 환경으로 전환하기 위해서 어떤 아키텍처를 가져야 하는지 알아보자. Cloud Native Architecture(클라우드 네이티브 아키텍쳐)의 특징 1. 확장 가능한 아키텍처 시스템의 수평적 확장에 유연 → 더 많은 사용자 요청 처리 가능 확장된 서버로 시스템의 부하 분산, 가용성 분산 시스템 확장은 scale-up, scale-out으로 나눌 수 있다. scale-up : 하드웨어의 사양을 높이는 작업 ex) 가지고 있는 시스템의 CPU나 메모리의 스펙을 높이는 작업(scalse-up) 등 scale-out : 같은 사양의 서버 즉 인스턴스를 여러 개 배치함으로써 동시에 더 많은 요청을 처리할 수 있도록 하는 것 이렇게 시스템을 양쪽으..
Software Architecture Antifragile 환경 1. Auto scaling(오토 스케일링) : 자동 확장성 시스템을 구정하고 있는 인스턴스를 하나의 오토 스케일링 그룹이라고 한다. 그리고 묶은 다음 그룹에서 유지되어야 하는 최소의 인스턴스를 지저할 수 있고 사용량에 따라 자동으로 인스턴스를 증가할 수 있는 환경 예시) 5월이나 12월 같이 특수한 이벤트가 있는 달에는 서버의 운영 개수를 늘리고 비수기와 같을 때는 서버의 운영 개수를 다시 줄이는 작업 2. Microservices(마이크로서비스) 마이크로 서비스라는 것은 클라우드 네이티브 아키텍처, 클라우드 네이티브 어플리케이션의 핵심 기존 시스템들이 하나의 거대한 형태로 구축되어서 서비스되었다고 하면 마이크로 서비스라는 것은 전체 서..
MSA란? MSA는 소프트웨어 개발 기법 중 하나로, 어플리케이션 단위를 '목적'으로 나누는 것 MSA 배경(Monolithic vs MSA) 모노리틱 아키텍쳐(Monolithic Architecture) 모노리틱 아키텍쳐 스타일은 기존의 전통적인 웹 시스템 개발 스타일로, 하나의 애플리케이션 내에 모든 로직들이 모두 들어 가 있는 “통짜 구조” 이다. 예를 들어, 온라인 쇼핑몰 애플리케이션이 있을때, 톰캣 서버에서 도는 WAR 파일(웹 애플리케이션 패키징 파일)내에, 사용자 관리,상품,주문 관리 모든 컴포넌트들이 들어 있고 이를 처리하는 UX 로직까지 하나로 포장되서 들어가 있는 구조이다. 장점 각 컴포넌트들은 상호 호출을 함수를 이용한 call-by-reference 구조를 취한다. 전체 애플리케이션..