logo

마이크로서비스 튜토리얼

마이크로서비스 튜토리얼

마이크로서비스 아키텍처 서비스 지향 아키텍처입니다. 마이크로서비스 아키텍처에는 수많은 마이크로서비스 . 모든 마이크로서비스를 결합하여 큰 서비스를 구축합니다. 마이크로서비스 아키텍처에서는 모든 서비스가 서로 통신합니다.

에서 마이크로서비스 튜토리얼을 통해 마이크로서비스를 구현하는 방법을 이해하겠습니다. 스프링 클라우드 . 마이크로서비스 간 통신을 구축하는 방법을 알아보겠습니다. ~할 수 있게 하다 로드 밸런싱 , 마이크로서비스 확장 및 축소 . 우리는 또한 다음을 배울 것입니다 마이크로서비스 구성을 중앙 집중화 ~와 함께 스프링 클라우드 구성 서버 . 우리는 구현합니다 유레카 네이밍 서버 그리고 분산 추적 ~와 함께 스프링 클라우드 슬루스 그리고 집킨 . 우리는 내결함성 마이크로서비스를 만들 것입니다. 집킨 .

우리의 마이크로서비스 튜토리얼에서는 기본 기능에 대해 설명합니다. 마이크로서비스 아키텍처 이해하기 쉽게 관련 예시를 함께 첨부합니다.

자바에서 날짜 형식 지정

마이크로서비스란?

정의 : 에 따르면 샘 뉴먼 , '마이크로서비스는 함께 작동하는 작은 서비스입니다.'

에 따르면 제임스 루이스와 마틴 파울러 , '마이크로서비스 아키텍처 스타일은 단일 애플리케이션을 소규모 서비스 모음으로 개발하는 접근 방식입니다. 각 마이크로서비스는 해당 프로세스를 실행하고 경량 메커니즘과 통신합니다. 이러한 서비스는 비즈니스 기능을 중심으로 구축되었으며 완전히 자동화된 배포 기계를 통해 독립적으로 개발되었습니다.'

이러한 서비스는 최소한의 중앙 집중식 관리가 가능하며, 이는 다양한 프로그래밍 언어로 작성되고 다양한 데이터 저장 기술을 사용할 수 있습니다.

기억해야 할 점

  • 이는 REST에 의해 노출되는 서비스입니다.
  • 이들은 잘 선택된 배치 가능한 소형 유닛입니다.
  • 서비스는 클라우드를 지원해야 합니다.

마이크로서비스는 애플리케이션을 비즈니스 요구 사항을 구현하는 느슨하게 결합된 서비스 풀로 나누는 아키텍처에 대한 접근 방식을 정의합니다. 옆에 있습니다 서비스 지향 아키텍처(SOA) . 마이크로서비스 기반 아키텍처의 가장 중요한 특징은 지속적인 전달 크고 복잡한 애플리케이션의

마이크로서비스는 애플리케이션을 중단하고 논리적으로 독립적인 소규모 애플리케이션을 구축하는 데 도움이 됩니다. 예를 들어, Amazon AWS의 도움으로 최소한의 노력으로 클라우드 애플리케이션을 구축할 수 있습니다.

마이크로서비스 소개

위 그림에서 각 마이크로서비스에는 자체 비즈니스 계층과 데이터베이스가 있습니다. 하나의 마이크로서비스를 변경해도 다른 서비스에는 영향을 미치지 않습니다. 이러한 서비스는 HTTP, REST 또는 메시징 프로토콜과 같은 경량 프로토콜을 사용하여 서로 통신합니다.

마이크로서비스의 원리

마이크로서비스에는 다음과 같은 원칙이 있습니다.

  • 단일 책임 원칙
  • 비즈니스 도메인을 중심으로 모델링됨
  • 장애 분리
  • 인프라 자동화
  • 독립적으로 배포

단일 책임 원칙

단일 책임 원칙은 프로그램의 클래스나 모듈이 하나의 책임만 가져야 함을 나타냅니다. 마이크로서비스는 한 번에 두 가지 이상의 책임을 수행할 수 없습니다.

비즈니스 도메인을 중심으로 모델링됨

마이크로서비스는 적절한 기술 스택이나 데이터베이스를 수용하는 데 결코 제한을 두지 않습니다. 스택이나 데이터베이스는 비즈니스 목적을 해결하는 데 가장 적합합니다.

고립된 고장

대규모 애플리케이션은 단일 모듈의 오류로 인해 대부분 영향을 받지 않을 수 있습니다. 서비스는 언제든지 실패할 수 있습니다. 따라서 장애를 신속하게 감지하고 가능하면 장애를 자동으로 복원하는 것이 중요합니다.

인프라 자동화

인프라 자동화는 환경을 스크립팅하는 프로세스입니다. 스크립팅 환경의 도움으로 단일 노드 또는 수천 개의 노드에 동일한 구성을 적용할 수 있습니다. 구성 관리, 스크립트 기반 인프라, 시스템 구성 관리라고도 합니다.

독립적으로 배포

마이크로서비스는 플랫폼에 구애받지 않습니다. 이는 다른 서비스에 영향을 주지 않고 독립적으로 설계하고 배포할 수 있음을 의미합니다.

청중

우리의 마이크로서비스 튜토리얼은 마이크로서비스 아키텍처를 쉬운 단계로 배우고 싶어하는 소프트웨어 전문가와 초보자를 위해 설계되었습니다. 이 튜토리얼은 마이크로서비스 아키텍처와 그 구성 요소에 대한 심층적인 지식을 제공합니다. RabbitMQ 서버, 유레카 네이밍 서버, Zuul API 게이트웨이, 리본, Hystrix, 그리고 집킨 서버 . 이 튜토리얼을 마친 후에는 다음을 개발할 수 있습니다. 마이크로서비스 서비스 ~와 함께 스프링 클라우드 .

전제조건

이 튜토리얼을 계속하기 전에 다음 사항에 대한 기본적인 이해가 있어야 합니다. 자바 , 봄, 그리고 스프링 클라우드 뼈대. 왜냐하면 우리는 Spring Cloud를 사용하여 마이크로서비스를 개발할 것이기 때문입니다.

문제

마이크로서비스 튜토리얼에서 어떤 문제도 발견하지 못할 것이라고 확신합니다. 잘못된 부분이 있으면 문의 양식에 문제를 게시해 주세요.