設置預設的超時和重試是一個基礎設施的基本素養

来源:https://www.cnblogs.com/xiexj/archive/2019/04/16/10702100.html
-Advertisement-
Play Games

What 本篇應該是穩定性「三十六計」系列的一篇:超時重試。但是「設置預設的超時和重試是一個基礎設施的基本素養」這句話我在我們組內三次開會的時候都說了。表達了我的一個理念。 Why 為什麼一個基礎設施要設置預設的超時和重試?想象下麵一個場景。 TCP協議里有一些基本的概念:MSL、TTL、RTT。 ...


What

本篇應該是穩定性「三十六計」系列的一篇:超時重試。但是「設置預設的超時和重試是一個基礎設施的基本素養」這句話我在我們組內三次開會的時候都說了。表達了我的一個理念。

 

Why

為什麼一個基礎設施要設置預設的超時和重試?想象下麵一個場景。

TCP協議里有一些基本的概念:MSL、TTL、RTT。

MSL(Maximum Segment Lifetime)

報文最大生存時間,它是任何報文在網路上存在的最長時間。超時報文就被丟棄。

TTL(Time To Live)

生存時間,是由源主機設置初始值,經常存的是ip數據包可以經過的最大路由數,每經過一個處理路由數減1,當值為0則報文被丟棄。

RTT(Round-trip time)

客戶端到伺服器往返所花時間。

 

嗯?不是很明白?這就對了。想象這些東西都沒有預設值,需要我們自己去設置,是不是很頭大?

作為基礎設施,自己應該是做過數據統計的、做過壓測的。自己的性能是什麼樣的,怎麼使用更為合理,基礎設施的開發團隊最為清楚,不應該將這種設置的責任交給調用方或者客戶端來做,加大對基礎設施的學習成本。

 

再來討論一個問題:為什麼要超時和重試?

長尾問題

 

如上圖,隨便找了一個調用的耗時。從上面可以看到平均耗時13.9ms,百分之99的耗時在30ms內,最大耗時有488ms。那對於超過100ms的請求來說,是不是在30ms內還不返回就直接丟棄這個請求重新發起一個,新請求有99%的概率在30ms內返回結果,從時間上更划算?

而之所以對同一個請求性能差距很大,原因很多,常見的有服務過載和隊列過長。

死鎖問題

想象一個分散式鎖,沒有超時時間。萬一釋放鎖時失敗了,其他人永遠不能獲取這個鎖。而如果有超時時間,鎖過期後,其他的請求通過重試是可以獲取到鎖的。

 

How

怎麼設置超時和重試。guava-trying是個不錯的java實現。其實不管什麼語言都不是難事,難的是超時和重試條件是什麼,設置多少合理。

超時和重試條件根據業務不同有差異。

一般的超時條件可設置為TP95(95%的請求)的2倍。或者智能一點,根據大數據統計一下,用個機器學習演算法看看怎麼設置總體耗時最小。

重試的一個比較好的實踐是每次重試的時間間隔成指數級增長,並且根據集群情況設置合理上限。這樣就避免本來服務已經過載了,短時間內大量重試造成多米諾骨牌效應(雪崩)。

合理的上限相當重要,因為有些請求不應該再重試了。比如伺服器過載時限流策略收到請求不會將請求交給執行層而是直接返回一個響應。而如果客戶端判斷:“我去,這麼快就給我結果啦!太好了,下個請求繼續給力哦~~”這種錯誤的正反饋循壞可能會成為資源耗盡的最後一根稻草。

 

相關閱讀

編寫代碼的「八榮八恥」(上篇)

編寫代碼的「八榮八恥」- 以開關上線為榮,以自信編碼為恥

穩定性「三十六計」- 配額管控

「前任的50種死法」開發踩坑案例--慢就是錯

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在使用生成的 圖作為``標簽是src值時,發現有部分瀏覽器顯示異常,所以這裡記錄下 參考鏈接 Data URLs http://www.faqs.org/rfcs/rfc2397.html https://developer.mozilla.org/zh CN/docs/Web/HTTP/data_ ...
  • 效果圖: 代碼如下: </head> <style> body{ background-color:#000; } .textArea{ font-size:100px; color:#fff; text-shadow:0 0 5px #e0ea33, 0 0 15px #e0ea33, 0 0 2 ...
  • 文章首發: "結構型模式:適配器模式" 七大結構型模式之一:適配器模式。 簡介 姓名 :適配器模式 英文名 :Adapter Pattern 價值觀 :老媒人,牽線搭橋 個人介紹 : Convert the interface of a class into another interface cl ...
  • 背景 隨著容器化、雲原生等的流行,DevOps團隊也在不斷鼓吹「以無狀態為榮,以有狀態為恥」。因為有狀態的服務難以部署、難以擴展。下麵我舉幾個自己工作中實際的例子。 實例1-依賴系統目錄結構 剛轉來基礎架構的時候,接手了一個服務,原來是個應屆生寫的。所以可以理解,也就是基本能完成功能,反正也不是核心 ...
  • 首先我們要下載一個PowerDesigner,自己上百度下載哈!嘻嘻!!! 我這個是漢化版的 然後點這個,再到空白的地方點一下就創建好了。 然後單擊右邊箭頭然後雙擊 不管是製作的圖還是代碼生成的圖都可以一鍵生成代碼文本文件 PowerDesigner的功能還是很強大的,還有很多新花樣等著我們去挖掘! ...
  • 在web.xml文件中配置字元編碼過濾器: ...
  • 工廠模式的學習篇幅比較長,小編第一次看書的時候,就一口氣花了一個多小時,還是通讀。後面又斷斷續續地繼續瞭解了下,力爭做到清晰的認知,給大家一個簡單的學習方式。所以,這次模塊分的可能會比之前的多,涉及到多個工廠模式。好的,我們繼續沖鴨!!! 除了使用new操作符之外,還有更多製造對象的方法。我們將瞭解 ...
  • IOC:控制反轉(Inversion of Control,英文縮寫為 IOC) 簡單來講就是把代碼的控制權從調用方(用戶)轉變成被調用方(服務端) 以前的代碼控制權在調用方,所以要每當程式要更新修改功能時,一定要大量修改調用方的代碼才行,工程量大,維護麻煩。 後來有了IOC,可以將所有的功能模塊交 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...