구성 패턴
소프트웨어 구성은 소프트웨어 제품을 구축하는 방법을 의미합니다. 기본적으로 소프트웨어의 여러 모듈이 특정 비즈니스 목표를 위해 통신하는 고수준 소프트웨어 아키텍처 다이어그램을 다룹니다. 이 장에서는 조직에서 널리 사용되는 다양한 소프트웨어 구성 패턴에 대해 알아 봅니다. 마이크로 서비스에서는 각 기능을 하나의 프로세스로 분할합니다. 이러한 각 서비스는 본질적으로 독립적이며 풀 스택입니다.
기능적 분해는 마이크로 서비스를 구축하는 데 중요한 역할을합니다. 애플리케이션에 민첩성, 유연성 및 확장 성을 제공합니다.
애그리 게이터 패턴
집계 패턴은 마이크로 서비스를 개발하는 동안 구현할 수있는 가장 간단한 웹 패턴입니다. 이 구성 패턴에서 간단한 웹 모듈은로드 밸런서 역할을하므로 요구 사항에 따라 다른 서비스를 호출합니다. 다음은 애그리 게이터 디자인을 사용하는 간단한 마이크로 서비스 웹앱을 나타내는 다이어그램입니다. 다음 이미지에서 볼 수 있듯이 "Aggregator"는 다른 서비스를 하나씩 호출해야합니다. 서비스 A, B 및 C의 결과에 비즈니스 논리를 적용해야하는 경우 집계 자 자체에서 비즈니스 논리를 구현할 수 있습니다.
애그리 게이터는 외부 세계에 또 다른 서비스로 다시 노출 될 수 있으며 필요할 때마다 다른 사람들이 사용할 수 있습니다. 애그리 게이터 패턴 웹 서비스를 개발하는 동안 각 서비스 A, B 및 C에는 자체 캐싱 레이어가 있어야하며 본질적으로 전체 스택이어야한다는 점을 명심해야합니다.
프록시 패턴
프록시 마이크로 서비스 패턴은 집 계기 모델의 변형입니다. 이 모델에서는 집계 모듈 대신 프록시 모듈을 사용합니다. 프록시 서비스는 다른 서비스를 개별적으로 호출 할 수 있습니다.
프록시 패턴에서는 덤프 프록시 계층을 제공하여 한 수준의 추가 보안을 구축 할 수 있습니다. 이 레이어는 인터페이스와 유사하게 작동합니다.
체인 패턴
이름에서 알 수 있듯이 이러한 유형의 구성 패턴은 체인 구조를 따릅니다. 여기서는 클라이언트와 서비스 계층 사이에 아무것도 사용하지 않습니다. 대신 클라이언트가 서비스와 직접 통신 할 수 있도록 허용하고 모든 서비스는 한 서비스의 출력이 다음 서비스의 입력이되는 방식으로 연결됩니다. 다음 이미지는 일반적인 체인 패턴 마이크로 서비스를 보여줍니다.
이 아키텍처의 한 가지 주요 단점은 전체 프로세스가 완료 될 때까지 클라이언트가 차단된다는 것입니다. 따라서 체인의 길이를 가능한 짧게 유지하는 것이 좋습니다.
분기 마이크로 서비스 패턴
분기 마이크로 서비스는 집계 패턴 및 체인 패턴의 확장 버전입니다. 이 디자인 패턴에서 클라이언트는 서비스와 직접 통신 할 수 있습니다. 또한 하나의 서비스는 한 번에 둘 이상의 서비스와 통신 할 수 있습니다. 다음은 Branch Microservice의 다이어그램 표현입니다.
분기 마이크로 서비스 패턴을 통해 개발자는 서비스 호출을 동적으로 구성 할 수 있습니다. 모든 서비스 호출은 동시에 발생합니다. 즉, 서비스 A가 서비스 B와 C를 동시에 호출 할 수 있습니다.
공유 리소스 패턴
공유 리소스 패턴은 실제로 앞에서 언급 한 모든 유형의 패턴을 결합한 집합체입니다. 이 패턴에서 클라이언트 또는로드 밸런서는 필요할 때마다 각 서비스와 직접 통신합니다. 이것은 대부분의 조직에서 널리 따르는 가장 효과적인 디자인 패턴입니다. 다음은 공유 리소스 디자인 패턴의 다이어그램 표현입니다.