


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
- Standard-Backoff: Wenn MinimumBackoff auf 5 Sekunden und MaximumBackoff auf 60 Sekunden eingestellt ist, erhöht sich die Zeit zwischen Wiederholungsversuchen schrittweise mit einem durchschnittlichen Intervall von ca. 10s. Dies weist auf einen RandomizationFactor nahe 1 hin.
- Kleinerer Backoff: Wenn MinimumBackoff und MaximumBackoff auf 1s bzw. 2s eingestellt sind, beträgt die Zeit zwischen Wiederholungsversuchen konstant etwa 3s. Dies deutet darauf hin, dass in diesem Fall das MaximumBackoff-Limit Vorrang hat.
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!

Golang zeichnet sich in praktischen Anwendungen aus und ist für seine Einfachheit, Effizienz und Parallelität bekannt. 1) Die gleichzeitige Programmierung wird über Goroutinen und Kanäle implementiert, 2) Flexibler Code wird unter Verwendung von Schnittstellen und Polymorphismen geschrieben, 3) Vereinfachen Sie die Netzwerkprogrammierung mit NET/HTTP -Paketen, 4) Effiziente gleichzeitige Crawler erstellen, 5) Debuggen und Optimierung durch Tools und Best Practices.

Zu den Kernmerkmalen von GO gehören die Müllsammlung, statische Verknüpfung und Unterstützung der Parallelität. 1. Das Parallelitätsmodell von GO -Sprache realisiert eine effiziente gleichzeitige Programmierung durch Goroutine und Kanal. 2. Schnittstellen und Polymorphismen werden durch Schnittstellenmethoden implementiert, so dass verschiedene Typen einheitlich verarbeitet werden können. 3. Die grundlegende Verwendung zeigt die Effizienz der Funktionsdefinition und des Aufrufs. 4. In der fortgeschrittenen Verwendung bieten Scheiben leistungsstarke Funktionen der dynamischen Größenänderung. 5. Häufige Fehler wie Rassenbedingungen können durch Getest-Race erkannt und gelöst werden. 6. Leistungsoptimierung wiederverwenden Objekte durch Sync.Pool, um den Druck der Müllabfuhr zu verringern.

Go Language funktioniert gut beim Aufbau effizienter und skalierbarer Systeme. Zu den Vorteilen gehören: 1. hohe Leistung: Kompiliert in den Maschinencode, schnelle Laufgeschwindigkeit; 2. gleichzeitige Programmierung: Vereinfachen Sie Multitasking durch Goroutinen und Kanäle; 3. Einfachheit: präzise Syntax, Reduzierung der Lern- und Wartungskosten; 4. plattform: Unterstützt die plattformübergreifende Kompilierung, einfache Bereitstellung.

Verwirrt über die Sortierung von SQL -Abfragenergebnissen. Während des Lernens von SQL stoßen Sie häufig auf einige verwirrende Probleme. Vor kurzem liest der Autor "Mick-SQL Basics" ...

Die Beziehung zwischen Technologiestapelkonvergenz und Technologieauswahl in der Softwareentwicklung, der Auswahl und dem Management von Technologiestapeln ist ein sehr kritisches Problem. In letzter Zeit haben einige Leser vorgeschlagen ...

Golang ...

Wie man drei Strukturen in der GO -Sprache vergleicht und umgeht. Bei der Go -Programmierung ist es manchmal notwendig, die Unterschiede zwischen zwei Strukturen zu vergleichen und diese Unterschiede auf die ...

Wie kann ich weltweit installierte Pakete in GO betrachten? Bei der Entwicklung mit GO -Sprache verwendet GO oft ...


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung

DVWA
Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

Sicherer Prüfungsbrowser
Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.