Saga pattern - AWS 규범적 지침

기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.

Saga pattern

saga 패턴은 분산 애플리케이션의 일관성을 유지하고 여러 마이크로서비스 간의 트랜잭션을 조정하여 데이터 일관성을 유지하는 데 도움이 되는 장애 관리 패턴입니다. 마이크로서비스는 모든 트랜잭션에 대한 이벤트를 게시하고, 이벤트 결과에 따라 다음 트랜잭션이 시작됩니다. 트랜잭션의 성공 또는 실패에 따라 두 가지 경로를 사용할 수 있습니다.

다음 그림은 saga 패턴이 AWS Step Functions을 사용하여 주문 처리 시스템을 구현하는 방법을 보여줍니다. 또한 각 단계 (예: “ProcessPayment”) 에는 프로세스의 성공 (예: "UpdateCustomerAccount“) 또는 실패 (예:" “) 를 처리하기 위한 별도의 단계가 있습니다. SetOrderFailure

Saga pattern

다음과 같은 경우에는 이 패턴을 사용하는 것이 좋습니다:

  • 애플리케이션은 긴밀한 결합 없이 여러 마이크로서비스 전반에서 데이터 일관성을 유지해야 합니다.

  • 트랜잭션은 오래 지속되므로 한 마이크로서비스가 오랫동안 실행되더라도 다른 마이크로서비스가 차단되는 것을 원하지 않을 것입니다.

  • 정해진 순서에 따라 작업이 실패하더라도 롤백할 수 있어야 합니다.

중요

saga 패턴은 디버깅하기 어렵고 마이크로서비스가 많아질수록 복잡성이 증가합니다. 이 패턴에는 롤백 및 변경 실행 취소를 위한 보상 트랜잭션을 개발하고 설계하는 복잡한 프로그래밍 모델이 필요합니다.

마이크로서비스 아키텍처에서 saga 패턴을 구현하는 방법에 대한 자세한 내용은 AWS 권장 가이드 웹 사이트에서 AWS Step Functions을 사용한 서버리스 saga 패턴의 구현 패턴을 참조하십시오.