Eventarc를 사용한 이벤트 기반 아키텍처 개요

Eventarc 및 Datastore 모드의 Firestore를 사용하여 이벤트 기반 아키텍처를 빌드할 수 있습니다. Datastore 모드의 Firestore는 데이터베이스의 특정 항목이 변경될 때 이벤트를 생성하는 Eventarc 트리거를 제공합니다. 트리거는 이벤트를 지원되는 대상으로 라우팅할 수 있습니다.

Eventarc는 분리된 마이크로서비스 간에 상태 변경 흐름(이벤트라고 함)을 관리하는 표준화된 솔루션을 제공합니다. 트리거된 Eventarc는 전송, 보안, 승인, 관측 가능성, 오류 처리를 관리하면서 이러한 이벤트를 다양한 대상으로 라우팅합니다.

사용 사례 예시

이벤트 기반 아키텍처는 서비스가 이벤트라고 하는 상태 변화에 대응하는 시스템 설계 패턴입니다. 이 패턴을 Firestore의 확장성과 함께 사용하여 앱에 기능을 추가할 수 있습니다. 예를 들어 다음 기능을 추가할 수 있습니다.

  • 여러 기술 스택 간의 상호 운용성

    데이터를 복제하고 분석 시스템으로 전송하기 전에 변환

  • 병렬 처리

    병렬 처리를 위한 팬아웃 작업. 항목 변경사항을 기반으로 작동하는 여러 시스템이 있는 경우 각 소비자의 내보내기 기반 스트림을 사용하고 이벤트를 여러 소비자에게 라우팅할 수 있습니다.

  • 내보내기 기반 이벤트 스트림

    내보내기 기반 메시징 설계를 빌드합니다. 클라이언트가 원격 서비스를 폴링할 필요 없이 알림을 수신할 수 있습니다. 폴링 지연 시간이 없으면 즉시 데이터 처리 및 실시간 분석을 더 잘 수행할 수 있습니다.

  • 상태 모니터링 및 알림

    이벤트 기반 아키텍처를 사용하여 데이터베이스 작업에 커스텀 측정항목을 추가합니다. 변경사항 및 업데이트에 대한 알림을 모니터링하고 수신합니다. 이상치를 감지합니다.

제한사항

Eventarc용 Datastore 모드 트리거의 다음 제한사항에 유의하세요.

  • 순서는 보장되지 않습니다. 급격하게 변경하면 예기치 않은 순서로 이벤트가 트리거될 수 있습니다.
  • 이벤트는 최소 한 번은 전송됩니다.

    이벤트 핸들러가 멱등성을 갖는지 확인하고 이벤트가 두 번 이상 전송될 때 예기치 않은 결과 또는 부작용이 발생하지 않도록 합니다. 자세한 내용은 멱등 함수 빌드를 참조하세요.

  • 트리거는 단일 데이터베이스와 연결됩니다. 여러 데이터베이스와 일치하는 트리거를 만들 수 없습니다.

  • 데이터베이스를 삭제해도 해당 데이터베이스의 트리거가 자동으로 삭제되지 않습니다. 트리거가 이벤트 제공을 중지하지만 트리거를 삭제하기 전까지 계속 존재합니다.

Datastore 모드의 Eventarc 및 Firestore 위치

Eventarc는 Firestore 이벤트 트리거에서 멀티 리전을 지원하지 않지만 멀티 리전 위치에서 Firestore 데이터베이스에 대한 트리거를 만들 수 있습니다. Eventarc는 Firestore 멀티 리전 위치를 다음 Eventarc 리전에 매핑합니다.

Firestore 멀티 리전 Eventarc 리전
nam5 us-central1
eur3 europe-west4

Datastore 모드 및 Native 모드 이벤트 상호 운용성

Eventarc는 Datastore 모드와 Native 모드의 이벤트 트리거를 지원합니다. 이러한 이벤트 트리거를 두 데이터베이스 유형과 상호 운용할 수 있습니다. Native 모드 데이터베이스의 Firestore는 Datastore 이벤트를 수신하고 Datastore 모드의 Firestore 데이터베이스는 Native 모드 이벤트를 수신할 수 있습니다.

이벤트 상호 운용성을 사용하면 서로 다른 유형의 Firestore 데이터베이스에서 Eventarc 코드를 공유할 수 있습니다.

이벤트 전환

Datastore 모드 데이터베이스에 Native 모드 이벤트 트리거를 적용하면 Eventarc에서 다음과 같은 변환을 수행합니다.

  • 항목의 네임스페이스는 이벤트의 PartitionId 속성에 저장됩니다.
  • 삽입된 항목은 Native 모드 map 유형으로 변환됩니다.

다음 단계