Google Pub/Sub 的RetryPolicy 中的指數退避如何運作
Google Pub/Sub 的cloud.google.com/go/pubsub 庫中的RetryPolicy 提供指數退避作為可設定的功能,以增強Pub/Sub 與其客戶端之間通訊的可靠性。
了解指數退避
指數退避涉及以指數方式增加重試之間的延遲。這可以防止過度重試導致伺服器不堪重負,並確保更漸進的重新連接。
在 RetryPolicy 配置中,MinimumBackoff 相當於中的 InitialInterval github.com/cenkalti/Internet 程式碼對應
MinimumBackoff 設定第一次重試之前的初始等待時間,而 MaximumBackoff 表示重試之間允許的最大延遲。預設情況下,MinimumBackoff 為 10 秒,MaximumBackoff 為 10 分鐘。
計算等待間隔
Pub/Sub 根據隨機指數計算重試之間的等待間隔退避公式:
`
隨機間隔=<pre class="brush:php;toolbar:false">RetryInterval * (random value in range [1 - RandomizationFactor, 1 + RandomizationFactor])
`其中RetryInterval 是目前重試間隔,初始為MaximumBackoff,並且受MaximumBackoff 限制。
最大重試嘗試次數
與github.com/cenkalti/backoff 函式庫的MaxElapsedTime 功能不同,Pub/Sub RetryPolicy 不有一個等效的選項來限制重試嘗試。相反,它建議在應限制重試的情況下使用死信佇列 (DLQ)。
隨機化
Pub/Sub RetryPolicy 使用隨機組件來在重試間隔中引入差異,確保具有相同配置的多個客戶端不會以完全相同的間隔重試。
您的實驗觀察結果
您的實驗觀察結果反映指數退避行為。使用 1 秒的最小退避和 2 秒的最大退避,您注意到 nack 之間有相對一致的約 3 秒延遲,表示最大退避 2 秒。
重試之間沒有加倍間隔表示沒有應用明確乘數。此外,您沒有觀察到重試次數有任何硬性限制,支援使用 DLQ 來限制重試嘗試的建議。
在 RetryPolicy 配置中,MinimumBackoff 相當於中的 InitialInterval github.com/cenkalti/Internet 程式碼對應
MinimumBackoff 設定第一次重試之前的初始等待時間,而 MaximumBackoff 表示重試之間允許的最大延遲。預設情況下,MinimumBackoff 為 10 秒,MaximumBackoff 為 10 分鐘。
計算等待間隔
Pub/Sub 根據隨機指數計算重試之間的等待間隔退避公式:
`
隨機間隔=<pre class="brush:php;toolbar:false">RetryInterval * (random value in range [1 - RandomizationFactor, 1 + RandomizationFactor])`
其中RetryInterval 是目前重試間隔,初始為MaximumBackoff,並且受MaximumBackoff 限制。
最大重試嘗試次數
與github.com/cenkalti/backoff 函式庫的MaxElapsedTime 功能不同,Pub/Sub RetryPolicy 不有一個等效的選項來限制重試嘗試。相反,它建議在應限制重試的情況下使用死信佇列 (DLQ)。
隨機化
Pub/Sub RetryPolicy 使用隨機組件來在重試間隔中引入差異,確保具有相同配置的多個客戶端不會以完全相同的間隔重試。
您的實驗觀察結果
您的實驗觀察結果反映指數退避行為。使用 1 秒的最小退避和 2 秒的最大退避,您注意到 nack 之間有相對一致的約 3 秒延遲,表示最大退避 2 秒。
重試之間沒有加倍間隔表示沒有應用明確乘數。此外,您沒有觀察到重試次數有任何硬性限制,支援使用 DLQ 來限制重試嘗試的建議。
以上是Google Pub/Sub 的 RetryPolicy 如何實現指數退避,它與其他退避函式庫有何不同?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文演示了創建模擬和存根進行單元測試。 它強調使用接口,提供模擬實現的示例,並討論最佳實踐,例如保持模擬集中並使用斷言庫。 文章

本文探討了GO的仿製藥自定義類型約束。 它詳細介紹了界面如何定義通用功能的最低類型要求,從而改善了類型的安全性和代碼可重複使用性。 本文還討論了局限性和最佳實踐

本文使用跟踪工具探討了GO應用程序執行流。 它討論了手冊和自動儀器技術,比較諸如Jaeger,Zipkin和Opentelemetry之類的工具,並突出顯示有效的數據可視化

本文討論了GO的反思軟件包,用於運行時操作代碼,對序列化,通用編程等有益。它警告性能成本,例如較慢的執行和更高的內存使用,建議明智的使用和最佳

本文討論了通過go.mod,涵蓋規範,更新和衝突解決方案管理GO模塊依賴關係。它強調了最佳實踐,例如語義版本控制和定期更新。

本文討論了GO中使用表驅動的測試,該方法使用測試用例表來測試具有多個輸入和結果的功能。它突出了諸如提高的可讀性,降低重複,可伸縮性,一致性和A


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Linux新版
SublimeText3 Linux最新版

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境