後端服務之應用預熱

来源:https://www.cnblogs.com/jingdongkeji/archive/2023/09/25/17727963.html
-Advertisement-
Play Games

一 背景 C端服務應用升級和重啟,導致耗時瞬時抖動,業務超時,應用監控報警,上游感知明顯,導致用戶體驗變差。 二 應用升級重啟導致抖動的原因 1 C端服務應用升級和重啟的冷啟動階段,它需要重新載入和初始化各種資源,例如資料庫連接、緩存數據等,導致耗時瞬時飆升。 2 應用重啟後,本地緩存失效,應用需要 ...


一 背景

C端服務應用升級和重啟,導致耗時瞬時抖動,業務超時,應用監控報警,上游感知明顯,導致用戶體驗變差。

二 應用升級重啟導致抖動的原因

1 C端服務應用升級和重啟的冷啟動階段,它需要重新載入和初始化各種資源,例如資料庫連接、緩存數據等,導致耗時瞬時飆升。

2 應用重啟後,本地緩存失效,應用需要重新載入數據,導致耗時變長。

3 應用重啟後,有大量請求堆積,導致系統負載增加,線程處理不及時,導致系統響應變慢。

三 解決方案

1 停服時,先下線JSF介面,再升級應用,待應用啟動成功後,JSF服務介面延遲註冊到註冊中心。

2 JSF開啟預熱功能,是服務提供者重啟後,JSF上線後,消費者與服務者建立鏈接後,調用方客戶端先放設置比例的小部分流量過來到升級重啟的實例,在預熱周期內,逐步到100%

3 在應用升級流程編排中,結合流量回放,編排流程,在流量回放後再操作JSF上線,實現略複雜,依賴基礎運維

方案1,方案2實現簡單,預熱效果也比較好,使用的是JSF的預熱功能,以下效果對比的實現來自方案2的JSF預熱功能。

四 採用JSF開啟預熱功能效果對比

1 服務提供者配置預熱周期

預熱初始權重:consumer連接到provider後,provider的初始權重(provider端權重會在預熱周期內會逐漸恢復到正常權重,一般是100)

2 未開啟預熱容器實例整體升級重啟監控:

應用部署在3個機房,所以看到3次抖動,可以看到TP999最高的機房達到了近25s。

開啟預熱後整體實例升級重啟效果:

應用部署在3個機房,所以看到3次抖動,可以看到TP999最高的機房降到了2.5s,降幅達10倍。

3 未開啟預熱,單實例應用重啟監控

max達到了20s,TP999到達了18s

開啟預熱後,單實例應用重啟監控

max降到了2s,TP999將到了1.5s左右,降幅達10倍,TPS在配置的預熱周期內(60s)呈現線性增長

五 註意事項

依賴服務調用方升級JSF到1.7.6版本及以上,推動所有調用方升級JSF

可根據應用的啟動時間和特性,調整應用匹配的預熱周期,達到相對預熱效果最好的狀態。至於是否有必要結合流量回放和流程編排實現預熱,需結合自己的業務情況和實現成本考慮。

作者:京東科技 張石磊

來源:京東雲開發者社區 轉載請註明來源


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

-Advertisement-
Play Games
更多相關文章
  • 在JDK 21中,Sequenced Collections的引入帶來了新的介面和方法來簡化集合處理。此增強功能旨在解決訪問Java中各種集合類型的第一個和最後一個元素需要非統一且麻煩處理場景。 下麵一起通過本文來瞭解一下不同集合處理示例。 Sequenced Collections介面 Seque ...
  • extern extern 是 C++ 中的一個關鍵字,用於聲明一個變數或函數是在其他文件中定義的。它的作用是告訴編譯器在鏈接時在其他文件中尋找該變數或函數的定義。 在 C++ 中,如果一個變數或函數在多個文件中使用,那麼就需要在每個文件中都聲明一次該變數或函數。這時就可以使用 extern 關鍵字 ...
  • 前言 最近寫一個任務隊列,可以支持存入返回值為void的任意函數對象。需要定義一個Task模板,來存儲函數對象以及參數。大致的實現如下: class Task { public: template <typename Func, typename... Args> Task(Func&& f, Ar ...
  • Python中有三種數字類型: int(整數) float(浮點數) complex(複數) 當您將值分配給變數時,將創建數字類型的變數: 示例:獲取您自己的Python伺服器 x = 1 # int y = 2.8 # float z = 1j # complex 要驗證Python中任何對象的類 ...
  • 1. 常規函數 函數都擁有顯示的類型簽名,其本身也是一種類型。 1.1 函數類型 自由函數 // 自由函數 fn sum(a: i32, b: i32) -> i32 { a+b } fn main() { assert_eq!(3, sum(1, 2)) } 關聯函數與方法 struct A(i3 ...
  • 近幾年來Laravel在PHP領域大放異彩,逐漸成為PHP開發框架中的中流砥柱。 這個系列的文章, 會帶你一起探知Laravel框架底層的實現細節。與其他框架相比,Laravel的設計理念確實更為先進(服務、容器、依賴註入、facade。。。),初讀代碼時會感覺代碼晦澀難懂,而一旦弄清了整套框架的基 ...
  • 1 摘要 通過使用記錄模式來增強Java編程語言,以解構記錄值。記錄模式和類型模式可嵌套使用,從而實現強大、聲明式和可組合的數據導航和處理形式。 2 發展史 由 JEP 405 提出的預覽功能,併在JDK 19發佈,然後由 JEP 432 再次預覽,併在JDK 20發佈。該功能與用於switch的模 ...
  • 來源:麥叔編程 作者:小K 前言 一個好的變數名能讓讀代碼的人(包括寫的人),身心舒暢,但一個“奇葩”的變數名可能會逼瘋一個程式員。 今天是奇葩變數名大賞! 正文 註:以下素材均採集自網路 先上場的是某企業機房的門牌: 我猜這個主任可能是個胡建人。 推薦一個開源免費的 Spring Boot 實戰項 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...