運維告訴我CPU飆升300%,為什么我的程序上線就奔潰了

線上服務CPU飆升

前言

  • 功能開發(fā)完成僅僅是項目周期中的第一步,一個完美的項目是在運行期體現(xiàn)的
  • 今天我們就來看看筆者之前遇到的一個問題CPU飆升的問題卸夕。 代碼層面從功能上看沒有任何問題但是投入使用后卻讓我頭大

問題描述

  • 系統(tǒng)上點擊數據錄入功能在全局監(jiān)控中會受到相關消息的通知。此時服務器CPU飆升300%

問題定位

  • 首先我們先梳理下Websocket的數據發(fā)送的簡單原理示意圖。往往定位問題得清楚我們的邏輯是什么
  • 當一個客戶端啟動時除了和Websocket建立連接之外,我們還需要向Websocket服務注冊當前客戶端需要哪些接口的實時數據
  • 我在代碼內部是通過一個Map來存儲這些接口簽名信息的烧颖。然后客戶注冊時候將這些接口和客戶端綁定在一起
  • 當我們監(jiān)聽程序堅挺到數據變動就會對綁定到相關接口的客戶端發(fā)送最新數據
image-20210510152226364

業(yè)務定位

  • 業(yè)務上很好定位,問題就是出現(xiàn)在我們的監(jiān)聽程序中窄陡。當監(jiān)聽到數據給websocket客戶端發(fā)送訂閱的最新變動接口時就會出現(xiàn)CPU飆升炕淮。持續(xù)時間還很長,稍等一會就會降下來
  • 這很明顯是我們推送消息的時候出現(xiàn)了問題
image-20210510161532550

隔離業(yè)務看本質

  • 作為一個合格的程序員呢跳夭,必須擺脫業(yè)務才能有所收獲 涂圆。業(yè)務是我們代碼的外殼所有的問題基本上都是我們本質的問題。我們線上使用用戶1W內币叹。在這種的并發(fā)場景下應該是不會出問題的∪笄福現(xiàn)在出了問題肯定我們的程序邏輯有缺陷
image-20210510162405407
  • 上面是我們的發(fā)送消息的代碼。代碼也很簡單颈抚。先獲取所有符合發(fā)送條件的客戶端 踩衩。然后通過客戶端內部提供的sendMessage方法進行推送。
  • 但是這個時候的message 是我們的接口信息贩汉。在內部會基于客戶端保存的方法簽名進行反射調用從而獲取最新數據驱富。在推送給客戶端的
  • 在上面的代碼中核心的是WebsocketManager.messageParse 。這段是獲取消息然后發(fā)送雾鬼。里面獲取消息是基于resultful格式解析的
image-20210510163121570
  • 這個方法內部我們有內置了我們的四種解析方式萌朱。這里我們只需要關心RequestMappingMessageParseHandlerImpl 這個協(xié)議。
image-20210510163300402
  • 關于我們內部的協(xié)議這里也不需要太在意策菜。這是我們自己的一個設計。根據上面的圖示我們也能看的出來里面RequestMappingMessageParseHandlerImpl 是核心
image-20210510163412669

產生原因

  • 上面我們簡單的梳理了下代碼的邏輯酒贬。
  • 仔細分析下我們是遍歷所有客戶端然后在反射調用接口數據進行返回的又憨。實際上在消息推送時我們沒必要在每個客戶端內部調用數據。我們完全可以先調用數據然后在遍歷客戶端進行發(fā)送锭吨。
  • 這也是導致CPU過高的問題蠢莺。我們1W個用戶同事在線的可能有5000+ 。 那么我們需要5000次以上的反射著肯定是吃不消的零如。這也是為什么本文開頭說功能正常不代表業(yè)務正常躏将。

解決方案

  • 這就是量變引起質變。在多客戶的情況下我們的設計弊端就暴露出來考蕾。這里也是筆者自己給自己挖坑祸憋。既然找到問題我們就好解決了。下面我們對代碼做了一下改動
image-20210510164137467
  • 我將數據緩存起來肖卧。因為在同一批次推送時本來也應該保證數據一致性蚯窥。而且我們系統(tǒng)對數據實時性也是可以接受一定時間延遲的。我在這里又加上緩存這樣就解決了我們循環(huán)的問題

  • 經過測試本次改動在CPU上大概優(yōu)化了100倍。

總結

  • 功能開發(fā)完成僅僅代表功能的實驗沒有問題
  • 單用戶和多用戶完全是兩種不同的用戶形態(tài)拦赠。我們功能設計初期就應該盡量考慮數據量的問題
  • 唯一做的好的地方是我通過責任鏈模式將數據解析隔離出來巍沙。否則這樣的問題定位將會更加麻煩
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市荷鼠,隨后出現(xiàn)的幾起案子句携,更是在濱河造成了極大的恐慌,老刑警劉巖允乐,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件矮嫉,死亡現(xiàn)場離奇詭異,居然都是意外死亡喳篇,警方通過查閱死者的電腦和手機敞临,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來麸澜,“玉大人挺尿,你說我怎么就攤上這事〈栋睿” “怎么了编矾?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長馁害。 經常有香客問我窄俏,道長,這世上最難降的妖魔是什么碘菜? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任凹蜈,我火速辦了婚禮,結果婚禮上忍啸,老公的妹妹穿的比我還像新娘仰坦。我一直安慰自己,他們只是感情好计雌,可當我...
    茶點故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布悄晃。 她就那樣靜靜地躺著,像睡著了一般凿滤。 火紅的嫁衣襯著肌膚如雪妈橄。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天翁脆,我揣著相機與錄音眷蚓,去河邊找鬼。 笑死鹃祖,一個胖子當著我的面吹牛溪椎,可吹牛的內容都是我干的普舆。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼校读,長吁一口氣:“原來是場噩夢啊……” “哼沼侣!你這毒婦竟也來了?” 一聲冷哼從身側響起歉秫,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤蛾洛,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后雁芙,有當地人在樹林里發(fā)現(xiàn)了一具尸體轧膘,經...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年兔甘,在試婚紗的時候發(fā)現(xiàn)自己被綠了谎碍。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡洞焙,死狀恐怖蟆淀,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情澡匪,我是刑警寧澤熔任,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站唁情,受9級特大地震影響疑苔,放射性物質發(fā)生泄漏。R本人自食惡果不足惜甸鸟,卻給世界環(huán)境...
    茶點故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一惦费、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧抢韭,春花似錦趁餐、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽季惯。三九已至吠各,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間勉抓,已是汗流浹背贾漏。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留藕筋,地道東北人纵散。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親伍掀。 傳聞我的和親對象是個殘疾皇子掰茶,可洞房花燭夜當晚...
    茶點故事閱讀 45,033評論 2 355

推薦閱讀更多精彩內容