> 백엔드 개발 > Golang > Google Pub/Sub\의 RetryPolicy 매개변수는 ExponentialBackOff 라이브러리의 InitialInterval 및 MaxInterval과 어떤 관련이 있나요?

Google Pub/Sub\의 RetryPolicy 매개변수는 ExponentialBackOff 라이브러리의 InitialInterval 및 MaxInterval과 어떤 관련이 있나요?

DDD
풀어 주다: 2024-10-27 17:40:03
원래의
804명이 탐색했습니다.

How do Google Pub/Sub's RetryPolicy Parameters Relate to the ExponentialBackOff Library's InitialInterval and MaxInterval?

Google Pub/Sub용 RetryPolicy의 지수 백오프

문제 설명

Google Pub/Sub의 RetryPolicy에는 최소 백오프 및 최대 백오프 매개변수가 포함되어 있습니다. 설명서에서는 이러한 값이 이산 시간의 지수 백오프에 사용된다고 설명합니다. 그러나 자주 사용되는 ExponentialBackOff 라이브러리의 InitialInterval 및 MaxInterval과 어떤 관련이 있는지에 대한 세부 정보는 제공하지 않습니다.

백오프 메커니즘

문서에서는 백오프 계산을 간략하게 보여줍니다. ExponentialBackOff 라이브러리에서 취한 접근 방식과 유사합니다.

randomized interval = RetryInterval * (random value in range [1 - RandomizationFactor, 1 + RandomizationFactor])
로그인 후 복사
  • RetryInterval은 재시도 사이의 현재 지연으로, 최소 백오프 값에서 시작하고 최대 백오프로 제한됩니다.
  • RandomizationFactor는 다음을 제공합니다. RetryInterval 주변의 무작위화 범위.

예제의 관찰

제공된 테스트 프로그램은 다양한 백오프 매개변수가 메시지 응답 간의 실제 지연에 미치는 영향을 보여줍니다.

  • MinimumBackoff와 MaximumBackoff를 각각 5초와 60초로 설정하면 Nack 간의 지연 시간이 점차 늘어나 6번째 시도에서는 1분에 도달합니다. 이는 시도할 때마다 RetryInterval이 두 배로 증가함을 의미합니다.
  • MinimumBackoff와 MaximumBackoff를 각각 1초와 2초로 설정하면 Nack 사이의 지연이 약 3초로 맴돌며 이는 MaximumBackoff 값보다 약간 높은 일관된 지연을 나타냅니다.

Multiplier 및 MaxElapsedTime

ExponentialBackOff 라이브러리에 정의된 Multiplier 및 MaxElapsedTime 매개변수는 Google Pub/Sub의 RetryPolicy에 직접적으로 상응하는 매개변수가 없습니다.

  • Multiplier는 설명서에 언급되지 않았으며 예제에서는 지연이 매번 두 배로 증가한다고 제안하지 않습니다.
  • MaxElapsedTime은 명시적으로 지원되지 않지만 설명서에는 MaximumBackoff가 0으로 설정된 경우 재시도가 무기한 계속된다는 내용이 나와 있습니다.

결론

Google Pub/Sub RetryPolicy의 MinimalBackoff 및 MaximumBackoff 매개변수는 무작위 지수 백오프 메커니즘을 사용하는 ExponentialBackOff 라이브러리의 InitialInterval 및 MaxInterval과 유사하게 작동합니다. 그러나 Google Pub/Sub는 재시도에 대한 승수 또는 최대 경과 시간을 명시적으로 지원하지 않습니다.

위 내용은 Google Pub/Sub의 RetryPolicy 매개변수는 ExponentialBackOff 라이브러리의 InitialInterval 및 MaxInterval과 어떤 관련이 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿