
來源:【公眾號】
Python技術(shù)
下午和老婆手牽手心連心去“好時光”照相館拍照片,記錄我們的美好時刻。
拍完一組照片,在等待攝影師修圖的時候,老婆站在我身后給我捶背,說我開車辛苦了,給我揉揉肩捶捶背。這待遇真是羨煞了路人甲,作為男人,這種滿足感也是無與倫比的。
這時候,作為一個男人,咱也不甘示弱:掏出手機,打開微信,點擊“轉(zhuǎn)賬”,輸入520,轉(zhuǎn)賬留言還不忘附一句“么么噠”。
一氣呵成之后,我提醒老婆趕緊看微信,老婆打開微信,刷了幾下,啥都沒看到,跑來問我說,看什么呀?
我提高嗓門說:給你發(fā)了個大包,你趕緊領(lǐng)了,過時不候哈!
哪里有大包嘛?你看看,啥也沒收到呀!
聽到這句話,我愣了一下,隨即冒了一絲冷汗:沒收到?難道我發(fā)錯人了?完了完了,趕緊檢查一下,要是發(fā)到另一個女孩的微信上就跳進黃河也洗不清了!
我趕忙打開手機,確認(rèn)了三遍,沒發(fā)錯,這才松了一口氣。我說你看,我已經(jīng)發(fā)過去了,你沒接收到,你是不是信號不好,你連 WiFi 看看!
老婆連了 WiFi,也還是沒看到。我打開手機微博,刷新內(nèi)容都沒問題,心理一百個為什么。。。
這時候修照片的老板娘(據(jù)說像某位明星)跟我們說,照片修好了,讓我們看看。我們看了之后說很滿意,把我嚴(yán)肅的表情修成了微笑,很棒!
接著老板娘讓我加她微信,把底片發(fā)給我。我微信掃一掃二維碼,添加了微信。可是老板娘等了半天,也沒有收到好友請求。我又添加了一次,還是一樣的結(jié)果。我不信邪,切換到了另一張聯(lián)通 5G 卡,又添加了一下,結(jié)果同樣沒收到。
我就郁悶了,這都 4G 加 5G ,一共 9G 了,怎么還是收不到請求呢?
結(jié)果讓老婆添加,一次性就成功了。
當(dāng)時賊郁悶,炫耀的紅包老婆沒有收到,明星老板娘的微信也沒加上,今天這人品是咋啦?
草草收場之后,我們離開了影樓,老婆路上還念叨著紅包,看著她可憐兮兮的樣子,我心疼啊,于是我又拿起手機轉(zhuǎn)了一個 520 過去,為了區(qū)分,我特意在轉(zhuǎn)賬留言后面加了一個企鵝發(fā)愛心的表情。
這次發(fā)過去她就看到了,以迅雷不及掩耳之勢點了紅包。令人意想不到的是,她收了紅包之后,馬上又冒出來一個,也就是之前沒收到的那個,這時候也出現(xiàn)了。毫無意外,以搶紅包的手速馬上又點了一次,欣喜若狂地對我說:謝謝老公,兩個紅包都收到了!
這殺千刀的微信,害人??!微信余額總共才 1000 出頭,這一下子掏空了,接下來日子怎么過??!大家可以理解我此時內(nèi)心的 OS 嗎?
晚上,回到家刷微博,無意間發(fā)現(xiàn)“微信bug”上了熱搜,看到微信官方的微博,才知道自己被微信坑了:
微信團隊表示,今天14點左右,部分微信用戶遇到了消息收取延遲情況,原因是系統(tǒng)抖動,目前已經(jīng)修復(fù)完成。
微信團隊還寬慰大家:你家網(wǎng)絡(luò)應(yīng)該沒啥問題。
我內(nèi)心想:我家網(wǎng)絡(luò)是沒問題,我家家庭和睦關(guān)系差點遭殃!
看了這個解釋,作為技術(shù)人員,我的第一反應(yīng)當(dāng)然是去了解一下什么是“系統(tǒng)抖動”,我去網(wǎng)上搜索相關(guān)資料,解釋是這樣的:
如果低優(yōu)先級進程所分配的幀數(shù)低于計算機體系結(jié)構(gòu)所需的最小數(shù)量,那么必須暫停該進程執(zhí)行。然后,應(yīng)調(diào)出它的所有剩余頁面,以便釋放所有分配的幀。這個規(guī)定引入了中級 CPU 調(diào)度的換進換出層。
事實上,需要研究一下沒有“足夠”幀的進程。如果進程沒有需要支持活動使用頁面的幀數(shù),那么它會很快產(chǎn)生缺頁錯誤。此時,必須置換某個頁面。然而,由于它的所有頁面都在使用中,所以必須立即置換需要再次使用的頁面。因此,它會再次快速產(chǎn)生缺頁錯誤,再一次置換必須立即返回的頁面,如此快速進行。
這種高度的頁面調(diào)度活動稱為抖動。如果一個進程的調(diào)頁時間多于它的執(zhí)行時間,那么這個進程就在抖動。
系統(tǒng)抖動的原因是什么呢?
操作系統(tǒng)監(jiān)視 CPU 利用率。如果 CPU 利用率太低,那么通過向系統(tǒng)引入新的進程來增加多道程度。采用全局置換算法會置換任何頁面,而不管這些頁面屬于哪個進程。
現(xiàn)在假設(shè)進程在執(zhí)行中進入一個新階段,并且需要更多的幀。它開始出現(xiàn)缺頁錯誤,并從其他進程那里獲取幀。然而,這些進程也需要這些頁面,因此它們也會出現(xiàn)缺頁錯誤,并且從其他進程中獲取幀。這些缺頁錯誤進程必須使用調(diào)頁設(shè)備以將頁面換進和換出。當(dāng)它們?yōu)檎{(diào)頁設(shè)備排隊時,就緒隊列清空。隨著進程等待調(diào)頁設(shè)備,CPU 利用率會降低。
CPU 調(diào)度程序看到 CPU 利用率的降低,進而會增加多道程度。新進程試圖從其他運行進程中獲取幀來啟動,從而導(dǎo)致更多的缺頁錯誤和更長的調(diào)頁設(shè)備隊列。因此,CPU 利用率進一步下降,并且 CPU 調(diào)度程序試圖再次增加多道程度。這樣就出現(xiàn)了抖動,系統(tǒng)吞吐量陡降,缺頁錯誤率顯著增加。結(jié)果,有效內(nèi)存訪問時間增加,沒有工作可以完成,因為進程總在忙于調(diào)頁。
在本次微信事件中,我們通俗的理解為:
所謂系統(tǒng)抖動(thrashing),是一個計算機專業(yè)名詞,指的是虛擬內(nèi)存方案中的一種現(xiàn)象,通常是因為內(nèi)存或其他資源耗盡或有限,導(dǎo)致無法完成所要執(zhí)行的操作。
當(dāng)上述情況發(fā)生時,程序就會通過操作系統(tǒng)發(fā)出請求,操作系統(tǒng)則試圖從其他程序中調(diào)用所需資源,導(dǎo)致新的請求不能得到滿足。
系統(tǒng)抖動發(fā)生時,系統(tǒng)時間會消耗在低速的I/O上,更多地進行頁面交換而不是指令執(zhí)行,進而大大降低系統(tǒng)效率。
用大白話說就是:微信消息收發(fā)系統(tǒng)的資源不夠用了。
今天雖然錢包空了,感覺損失了幾個億,并且差點好事變壞事,但是經(jīng)歷了一次微信的重大事件,而且學(xué)到了點新知識,也算是不小的收獲了!
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
SQL Server 中 CONVERT 函數(shù)的日期轉(zhuǎn)換:從基礎(chǔ)用法到實戰(zhàn)優(yōu)化 在 SQL Server 的數(shù)據(jù)處理中,日期格式轉(zhuǎn)換是高頻需求 —— 無論 ...
2025-09-18MySQL 大表拆分與關(guān)聯(lián)查詢效率:打破 “拆分必慢” 的認(rèn)知誤區(qū) 在 MySQL 數(shù)據(jù)庫管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數(shù)據(jù)分析師:表結(jié)構(gòu)數(shù)據(jù) “獲取 - 加工 - 使用” 全流程的賦能者 表結(jié)構(gòu)數(shù)據(jù)(如數(shù)據(jù)庫表、Excel 表、CSV 文件)是企業(yè)數(shù)字 ...
2025-09-18DSGE 模型中的 Et:理性預(yù)期算子的內(nèi)涵、作用與應(yīng)用解析 動態(tài)隨機一般均衡(Dynamic Stochastic General Equilibrium, DSGE)模 ...
2025-09-17Python 提取 TIF 中地名的完整指南 一、先明確:TIF 中的地名有哪兩種存在形式? 在開始提取前,需先判斷 TIF 文件的類型 —— ...
2025-09-17CDA 數(shù)據(jù)分析師:解鎖表結(jié)構(gòu)數(shù)據(jù)特征價值的專業(yè)核心 表結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 規(guī)范存儲的結(jié)構(gòu)化數(shù)據(jù),如數(shù)據(jù)庫表、Excel 表、 ...
2025-09-17Excel 導(dǎo)入數(shù)據(jù)含缺失值?詳解 dropna 函數(shù)的功能與實戰(zhàn)應(yīng)用 在用 Python(如 pandas 庫)處理 Excel 數(shù)據(jù)時,“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗與 t 檢驗:差異、適用場景與實踐應(yīng)用 在數(shù)據(jù)分析與統(tǒng)計學(xué)領(lǐng)域,假設(shè)檢驗是驗證研究假設(shè)、判斷數(shù)據(jù)差異是否 “ ...
2025-09-16CDA 數(shù)據(jù)分析師:掌控表格結(jié)構(gòu)數(shù)據(jù)全功能周期的專業(yè)操盤手 表格結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 存儲的結(jié)構(gòu)化數(shù)據(jù),如 Excel 表、數(shù)據(jù) ...
2025-09-16MySQL 執(zhí)行計劃中 rows 數(shù)量的準(zhǔn)確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調(diào)優(yōu)中,EXPLAIN執(zhí)行計劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對象的 text 與 content:區(qū)別、場景與實踐指南 在 Python 進行 HTTP 網(wǎng)絡(luò)請求開發(fā)時(如使用requests ...
2025-09-15CDA 數(shù)據(jù)分析師:激活表格結(jié)構(gòu)數(shù)據(jù)價值的核心操盤手 表格結(jié)構(gòu)數(shù)據(jù)(如 Excel 表格、數(shù)據(jù)庫表)是企業(yè)最基礎(chǔ)、最核心的數(shù)據(jù)形態(tài) ...
2025-09-15Python HTTP 請求工具對比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請求(如接口調(diào)用、數(shù)據(jù)爬取 ...
2025-09-12解決 pd.read_csv 讀取長浮點數(shù)據(jù)的科學(xué)計數(shù)法問題 為幫助 Python 數(shù)據(jù)從業(yè)者解決pd.read_csv讀取長浮點數(shù)據(jù)時的科學(xué)計數(shù)法問題 ...
2025-09-12CDA 數(shù)據(jù)分析師:業(yè)務(wù)數(shù)據(jù)分析步驟的落地者與價值優(yōu)化者 業(yè)務(wù)數(shù)據(jù)分析是企業(yè)解決日常運營問題、提升執(zhí)行效率的核心手段,其價值 ...
2025-09-12用 SQL 驗證業(yè)務(wù)邏輯:從規(guī)則拆解到數(shù)據(jù)把關(guān)的實戰(zhàn)指南 在業(yè)務(wù)系統(tǒng)落地過程中,“業(yè)務(wù)邏輯” 是連接 “需求設(shè)計” 與 “用戶體驗 ...
2025-09-11塔吉特百貨孕婦營銷案例:數(shù)據(jù)驅(qū)動下的精準(zhǔn)零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當(dāng)下,精準(zhǔn)營銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數(shù)據(jù)分析師與戰(zhàn)略 / 業(yè)務(wù)數(shù)據(jù)分析:概念辨析與協(xié)同價值 在數(shù)據(jù)驅(qū)動決策的體系中,“戰(zhàn)略數(shù)據(jù)分析”“業(yè)務(wù)數(shù)據(jù)分析” 是企業(yè) ...
2025-09-11Excel 數(shù)據(jù)聚類分析:從操作實踐到業(yè)務(wù)價值挖掘 在數(shù)據(jù)分析場景中,聚類分析作為 “無監(jiān)督分組” 的核心工具,能從雜亂數(shù)據(jù)中挖 ...
2025-09-10統(tǒng)計模型的核心目的:從數(shù)據(jù)解讀到?jīng)Q策支撐的價值導(dǎo)向 統(tǒng)計模型作為數(shù)據(jù)分析的核心工具,并非簡單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10