Heim >Backend-Entwicklung >Golang >Wie geht die RetryPolicy mit exponentiellem Backoff von Google Pub/Sub mit minimalem, maximalem Backoff und Randomisierung um?
So funktioniert der exponentielle Backoff in der RetryPolicy von Google Pub/Sub
Google Pub/Sub hat kürzlich eine RetryPolicy-Funktion eingeführt, um die Fehlerbehandlung im Server zu verbessern -seitige Operationen. Die Konfigurationsoptionen für diese Richtlinie umfassen die Parameter „MinimumBackoff“ und „MaximumBackoff“.
MinimumBackoff- und MaximumBackoff-Konfiguration
Der Parameter „MinimumBackoff“ gibt die anfängliche Wartezeit vor dem ersten Wiederholungsversuch an. Der MaximumBackoff-Parameter definiert die maximal zulässige Zeitspanne zwischen aufeinanderfolgenden Wiederholungsversuchen. Diese Parameter entsprechen dem InitialInterval und dem MaxInterval im exponentiellen Backoff-Algorithmus, der in github.com/cenkalti/backoff implementiert ist.
Exponentieller Backoff-Algorithmus
Beim exponentiellen Backoff ist jeder randomisiert Das Intervall wird mithilfe der Formel berechnet:
retryInterval = InitialInterval * (random value in range [1 - RandomizationFactor, 1 + RandomizationFactor])
wobei das InitialInterval MinimumBackoff ist und der Zufallswert eine Randomisierung in der Wiederholungsverzögerung einführt. Das Wiederholungsintervall wird durch MaximumBackoff begrenzt.
Beispielprogramm
Das bereitgestellte Programm demonstriert das Verhalten des exponentiellen Backoff-Algorithmus mit unterschiedlichen MinimumBackoff- und MaximumBackoff-Werten.
Beobachtungen aus der Programmausgabe
Randomisierung und Multiplikator
Der von RetryPolicy verwendete exponentielle Backoff-Algorithmus umfasst Randomisierung, um sicherzustellen, dass Wiederholungsversuche durchgeführt werden nicht immer im gleichen Intervall gemacht. Die Ausgabe des bereitgestellten Programms zeigt jedoch kein klares Muster exponentiellen Wachstums in den Wiederholungsintervallen, was darauf hindeutet, dass der Multiplier-Parameter, der das Wiederholungsintervall bei jeder Iteration verdoppeln würde, nicht verwendet wird.
MaxElapsedTime
Im Gegensatz zur exponentiellen Backoff-Implementierung in github.com/cenkalti/backoff verfügt RetryPolicy nicht über einen entsprechenden MaxElapsedTime-Parameter. Dies bedeutet, dass Wiederholungsversuche unbegrenzt fortgesetzt werden, wenn der Server nicht verfügbar ist, es sei denn, die Anwendung verarbeitet und begrenzt Wiederholungsversuche unabhängig.
Das obige ist der detaillierte Inhalt vonWie geht die RetryPolicy mit exponentiellem Backoff von Google Pub/Sub mit minimalem, maximalem Backoff und Randomisierung um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!