마이크로 서비스 아키텍처-소개

마이크로 서비스는 서비스 기반 애플리케이션 개발 방법론입니다. 이 방법론에서 큰 응용 프로그램은 가장 작은 독립 서비스 단위로 나뉩니다. 마이크로 서비스는 전체 애플리케이션을 상호 연결된 서비스 모음으로 분할하여 SOA (Service-Oriented Architecture)를 구현하는 프로세스입니다. 여기서 각 서비스는 하나의 비즈니스 요구 사항 만 충족합니다.

마이크로 화의 개념

서비스 지향 아키텍처에서 전체 소프트웨어 패키지는 상호 연결된 소규모 비즈니스 단위로 세분화됩니다. 이러한 각 소규모 비즈니스 단위는 서로 다른 프로토콜을 사용하여 서로 통신하여 고객에게 성공적인 비즈니스를 제공합니다. 이제 문제는 마이크로 서비스 아키텍처 (MSA)가 SOA와 어떻게 다른가입니다. 한마디로 SOA는 설계 패턴이고 Microservice는 SOA를 구현하는 구현 방법론이거나 Microservice가 SOA의 한 유형이라고 말할 수 있습니다.

다음은 마이크로 서비스 지향 애플리케이션을 개발할 때 염두에 두어야 할 몇 가지 규칙입니다.

  • Independent − 각 마이크로 서비스는 독립적으로 배포 할 수 있어야합니다.

  • Coupling − 모든 마이크로 서비스는 하나의 변경 사항이 다른 하나에 영향을 미치지 않도록 서로 느슨하게 결합되어야합니다.

  • Business Goal − 전체 애플리케이션의 각 서비스 단위는 가장 작고 하나의 특정 비즈니스 목표를 제공 할 수 있어야합니다.

마이크로 서비스를 심도있게 이해하기 위해 온라인 쇼핑 포털의 예를 살펴 보겠습니다. 이제이 전체 전자 상거래 포털을 사용자 관리, 주문 관리, 체크인, 지불 관리, 배송 관리 등과 같은 소규모 비즈니스 단위로 나눕니다. 하나의 성공적인 주문은 특정 시간 내에 이러한 모든 모듈을 통해 진행되어야합니다. 틀. 다음은 하나의 전자 상거래 시스템과 관련된 여러 비즈니스 단위의 통합 이미지입니다.

이러한 각 비즈니스 모듈에는 고유 한 비즈니스 논리와 이해 관계자가 있어야합니다. 특정 요구 사항을 위해 다른 타사 공급 업체 소프트웨어와 통신하며 서로 통신합니다. 예를 들어, 주문 관리는 사용자 정보를 얻기 위해 사용자 관리와 통신 할 수 있습니다.

이제 앞서 언급 한 모든 비즈니스 단위로 온라인 쇼핑 포털을 운영하고 있다는 점을 고려하면 프런트 엔드, 백 엔드, 데이터베이스 등과 같은 여러 계층으로 구성된 엔터프라이즈 수준의 애플리케이션이 필요합니다. 애플리케이션이 확장되지 않은 경우 하나의 단일 war 파일로 완전히 개발 된 다음 일반적인 모 놀리 식 애플리케이션으로 호출됩니다. IBM에 따르면 일반적인 모 놀리 식 애플리케이션은 내부적으로 하나의 엔드 포인트 또는 애플리케이션 만 모든 사용자 요청을 처리 할 책임이있는 다음 모듈 구조를 보유해야합니다.

위 이미지에서 서로 다른 사용자 및 비즈니스 데이터를 저장하기위한 Database와 같은 다양한 모듈을 볼 수 있습니다. 프런트 엔드에는 일반적으로 사용할 사용자 또는 비즈니스 데이터를 렌더링하는 다른 장치가 있습니다. 중간에는 배포 가능한 EAR 또는 WAR 파일이 될 수있는 하나의 패키지가 있습니다.이 파일은 사용자가 끝낸 요청을 수락하고 리소스의 도움을 받아 처리 한 다음 사용자에게 다시 렌더링합니다. 위의 예에서 비즈니스가 변경을 원할 때까지 모든 것이 잘 될 것입니다.

비즈니스 요구에 따라 애플리케이션을 변경해야하는 다음 시나리오를 고려하십시오.

사업부는 "검색"모듈에서 약간의 변경이 필요합니다. 그런 다음 전체 검색 프로세스를 변경하고 애플리케이션을 재배포해야합니다. 이 경우 변경 사항없이 다른 장치를 재배포합니다.

이제 귀하의 사업부는 "지갑"옵션을 포함하기 위해 "체크 아웃"모듈을 약간 변경해야합니다. 이제 "체크 아웃"모듈을 변경하고 동일한 모듈을 서버에 다시 배포해야합니다. 소프트웨어 패키지의 다른 모듈을 재배포하고 있지만 변경하지 않았습니다. 다음은 마이크로 서비스 아키텍처에 더 특정한 서비스 지향 아키텍처의 개념입니다. 소프트웨어의 모든 모듈이 하나의 비즈니스 작업을 독립적으로 처리 할 수있는 독립적 인 단위로 작동하는 방식으로 모 놀리 식 애플리케이션을 개발할 수 있습니다.

다음 예를 고려하십시오.

위의 아키텍처에서는 컴팩트 한 종단 간 서비스로 ear 파일을 생성하지 않습니다. 대신 소프트웨어의 다른 부분을 서비스로 노출하여 분할하고 있습니다. 소프트웨어의 모든 부분은 각 서비스를 사용하여 서로 쉽게 통신 할 수 있습니다. 이것이 바로 마이크로 서비스가 최신 웹 애플리케이션에서 큰 역할을하는 방법입니다.

마이크로 서비스 라인에서 장바구니 예를 비교해 보겠습니다. "검색", "필터", "결제", "장바구니", "추천"등과 같은 다른 모듈로 장바구니를 분류 할 수 있습니다. 장바구니 포털을 구축하려면 다음을 구축해야합니다. 위에서 언급 한 모듈을 서로 연결하여 연중 무휴 좋은 쇼핑 경험을 제공 할 수 있습니다.

장점 단점

다음은 모 놀리 식 애플리케이션을 사용하는 대신 마이크로 서비스를 사용할 때의 이점에 대한 몇 가지 사항입니다.

장점

  • Small in size− 마이크로 서비스는 SOA 설계 패턴의 구현입니다. 가능한 한 서비스를 유지하는 것이 좋습니다. 기본적으로 서비스는 하나 이상의 비즈니스 작업을 수행해서는 안되므로 다른 모 놀리 식 애플리케이션보다 크기가 작고 유지 관리가 쉽습니다.

  • Focused− 앞서 언급했듯이 각 마이크로 서비스는 하나의 비즈니스 작업 만 제공하도록 설계되었습니다. 마이크로 서비스를 설계하는 동안 설계자는 제공 가능한 서비스 인 서비스의 초점에 대해 염려해야합니다. 정의에 따라 하나의 마이크로 서비스는 본질적으로 풀 스택이어야하며 하나의 비즈니스 속성 만 제공해야합니다.

  • Autonomous− 각 마이크로 서비스는 전체 애플리케이션의 자율 비즈니스 단위 여야합니다. 따라서 응용 프로그램이 더 느슨하게 결합되어 유지 관리 비용을 줄이는 데 도움이됩니다.

  • Technology heterogeneity− 마이크로 서비스는 하나의 비즈니스 단위에서 서로 통신 할 수있는 다양한 기술을 지원하므로 개발자가 올바른 장소에서 올바른 기술을 사용할 수 있습니다. 이기종 시스템을 구현하면 최대의 보안, 속도 및 확장 가능한 시스템을 얻을 수 있습니다.

  • Resilience− 탄력성은 소프트웨어 장치를 분리하는 속성입니다. 마이크로 서비스는 구축 방법론에서 높은 수준의 복원력을 따르므로 한 단위가 실패 할 때마다 전체 비즈니스에 영향을 미치지 않습니다. 탄력성은 확장 성이 뛰어나고 결합이 적은 시스템을 구현하는 또 다른 속성입니다.

  • Ease of deployment− 전체 애플리케이션이 작은 단위로 세분화되기 때문에 모든 구성 요소는 본질적으로 풀 스택이어야합니다. 이들 모두는 동일한 종류의 다른 모 놀리 식 애플리케이션과 달리 시간 복잡성이 적은 모든 환경에서 매우 쉽게 배포 할 수 있습니다.

다음은 마이크로 서비스 아키텍처의 단점에 대한 몇 가지 사항입니다.

단점

  • Distributed system− 기술적 이질성으로 인해 마이크로 서비스의 여러 부분을 개발하는 데 서로 다른 기술이 사용됩니다. 이 큰 이기종 분산 소프트웨어를 지원하려면 수많은 숙련 된 전문가가 필요합니다. 따라서 분산 및 이질성은 마이크로 서비스 사용의 가장 큰 단점입니다.

  • Cost − 마이크로 서비스는 비즈니스 작업에 따라 다른 서버 공간을 유지해야하기 때문에 비용이 많이 듭니다.

  • Enterprise readiness− 마이크로 서비스 아키텍처는 기술이 날마다 진화하고 있기 때문에 다양한 기술의 대기업으로 간주 될 수 있습니다. 따라서 마이크로 서비스 애플리케이션 엔터프라이즈를 기존 소프트웨어 개발 모델과 비교할 준비가되도록 만드는 것은 매우 어렵습니다.

SOA를 통한 마이크로 서비스

다음 표는 SOA와 마이크로 서비스의 특정 기능을 나열하여 SOA보다 마이크로 서비스를 사용하는 것의 중요성을 보여줍니다.

구성 요소 SOA 마이크로 서비스
디자인 패턴 SOA는 컴퓨터 소프트웨어의 디자인 패러다임으로, 소프트웨어 구성 요소가 서비스 형태로 사용하기 위해 외부 세계에 노출됩니다. 마이크로 서비스는 SOA의 일부입니다. 이것은 SOA의 특수 구현입니다.
의존 비즈니스 단위는 서로 종속되어 있습니다. 모든 사업부는 서로 독립적입니다.
크기 소프트웨어 크기는 기존 소프트웨어보다 큽니다. 소프트웨어 크기가 작습니다.
과학 기술 기술 스택은 마이크로 서비스보다 적습니다. 마이크로 서비스는 특정 작업을 수행하는 데 정확한 기술이 사용되므로 본질적으로 이기종입니다. 마이크로 서비스는 많은 기술의 집합체로 간주 될 수 있습니다.
자율성과 집중 SOA 애플리케이션은 여러 비즈니스 작업을 수행하도록 구축되었습니다. 마이크로 서비스 애플리케이션은 단일 비즈니스 작업을 수행하도록 구축되었습니다.
자연 본질적으로 모 놀리 식. 자연의 전체 스택.
전개 배포에는 시간이 많이 걸립니다. 배포는 매우 쉽습니다. 따라서 시간이 덜 소요됩니다.
비용 효율성 더 비용 효율적입니다. 비용 효율성이 떨어집니다.
확장 성 마이크로 서비스에 비해 적습니다. 완전히 확장되었습니다.
하나의 온라인 CAB 예약 응용 프로그램을 고려해 보겠습니다. SOA를 사용하여 해당 응용 프로그램을 구축하려는 경우 소프트웨어 단위는 다음과 같습니다.
  • GetPayments 및 DriverInformation 및 MappingDataAPI
  • 사용자 및 드라이버 인증 API
동일한 애플리케이션이 마이크로 서비스 아키텍처를 사용하여 빌드 된 경우 해당 API는 다음과 같습니다.
  • SubmitPaymentsService
  • GetDriverInfoService
  • GetMappingDataService
  • AuthenticateUserService
  • AuthenticateDriverService