日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > > 小林coding
[導(dǎo)讀]最近,某團(tuán)外賣被爆出大數(shù)據(jù)殺熟,所謂的大數(shù)據(jù)殺熟指的是平臺(tái)利用戶的數(shù)據(jù),分析你是否是錢多的人,或者是否是不糾結(jié)價(jià)格的人,如果是,那么你買同樣的物品會(huì)比普通用戶貴一點(diǎn),一般這種沒(méi)有特地去對(duì)比價(jià)格是很難發(fā)現(xiàn)的,所以平臺(tái)就利用了這點(diǎn)額外賺一些錢。說(shuō)來(lái)很可笑,我們作為平臺(tái)的資深用戶,竟然被平臺(tái)背后偷偷撈一筆。不過(guò),大數(shù)據(jù)殺熟早已是屢見(jiàn)不鮮的事情了,事實(shí)上,幾乎所有大平臺(tái)都存在這種現(xiàn)象,沒(méi)辦法,這就是真實(shí)的互聯(lián)網(wǎng)。

最近,某團(tuán)外賣被爆出大數(shù)據(jù)殺熟,所謂的大數(shù)據(jù)殺熟指的是平臺(tái)利用戶的數(shù)據(jù),分析你是否是錢多的人,或者是否是不糾結(jié)價(jià)格的人,如果是,那么你買同樣的物品會(huì)比普通用戶貴一點(diǎn),一般這種沒(méi)有特地去對(duì)比價(jià)格是很難發(fā)現(xiàn)的,所以平臺(tái)就利用了這點(diǎn)額外賺一些錢。說(shuō)來(lái)很可笑,我們作為平臺(tái)的資深用戶,竟然被平臺(tái)背后偷偷撈一筆。

不過(guò),大數(shù)據(jù)殺熟早已是屢見(jiàn)不鮮的事情了,事實(shí)上,幾乎所有大平臺(tái)都存在這種現(xiàn)象,沒(méi)辦法,這就是真實(shí)的互聯(lián)網(wǎng)。

剎車,大數(shù)據(jù)殺熟的話題就說(shuō)到這了,我們還是回歸到今日的技術(shù)主題:什么是軟中斷?。


中斷是什么?

先來(lái)看看什么是中斷?在計(jì)算機(jī)中,中斷是系統(tǒng)用來(lái)響應(yīng)硬件設(shè)備請(qǐng)求的一種機(jī)制,操作系統(tǒng)收到硬件的中斷請(qǐng)求,會(huì)打斷正在執(zhí)行的進(jìn)程,然后調(diào)用內(nèi)核中的中斷處理程序來(lái)響應(yīng)請(qǐng)求。

這樣的解釋可能過(guò)于學(xué)術(shù)了,容易云里霧里,我就舉個(gè)生活中取外賣的例子。

小林中午搬完磚,肚子餓了,點(diǎn)了份白切雞外賣,這次我?guī)чW了,沒(méi)有被某團(tuán)大數(shù)據(jù)大熟。雖然平臺(tái)上會(huì)顯示配送進(jìn)度,但是我也不能一直傻傻地盯著呀,時(shí)間很寶貴,當(dāng)然得去干別的事情,等外賣到了配送員會(huì)通過(guò)「電話」通知我,電話響了,我就會(huì)停下手中地事情,去拿外賣。

這里的打電話,其實(shí)就是對(duì)應(yīng)計(jì)算機(jī)里的中斷,沒(méi)接到電話的時(shí)候,我可以做其他的事情,只有接到了電話,也就是發(fā)生中斷,我才會(huì)停下當(dāng)前的事情,去進(jìn)行另一個(gè)事情,也就是拿外賣。

從這個(gè)例子,我們可以知道,中斷是一種異步的事件處理機(jī)制,可以提高系統(tǒng)的并發(fā)處理能力。

操作系統(tǒng)收到了中斷請(qǐng)求,會(huì)打斷其他進(jìn)程的運(yùn)行,所以中斷請(qǐng)求的響應(yīng)程序,也就是中斷處理程序,要盡可能快的執(zhí)行完,這樣可以減少對(duì)正常進(jìn)程運(yùn)行調(diào)度地影響。

而且,中斷處理程序在響應(yīng)中斷時(shí),可能還會(huì)「臨時(shí)關(guān)閉中斷」,這意味著,如果當(dāng)前中斷處理程序沒(méi)有執(zhí)行完之前,系統(tǒng)中其他的中斷請(qǐng)求都無(wú)法被響應(yīng),也就說(shuō)中斷有可能會(huì)丟失,所以中斷處理程序要短且快。

還是回到外賣的例子,小林到了晚上又點(diǎn)起了外賣,這次為了犒勞自己,共點(diǎn)了兩份外賣,一份小龍蝦和一份奶茶,并且是由不同地配送員來(lái)配送,那么問(wèn)題來(lái)了,當(dāng)?shù)谝环萃赓u送到時(shí),配送員給我打了長(zhǎng)長(zhǎng)的電話,說(shuō)了一些雜七雜八的事情,比如給個(gè)好評(píng)等等,但如果這時(shí)另一位配送員也想給我打電話。

很明顯,這時(shí)第二位配送員因?yàn)槲以谕ㄔ捴校ㄏ喈?dāng)于關(guān)閉了中斷響應(yīng)),自然就無(wú)法打通我的電話,他可能嘗試了幾次后就走掉了(相當(dāng)于丟失了一次中斷)。


什么是軟中斷?

前面我們也提到了,中斷請(qǐng)求的處理程序應(yīng)該要短且快,這樣才能減少對(duì)正常進(jìn)程運(yùn)行調(diào)度地影響,而且中斷處理程序可能會(huì)暫時(shí)關(guān)閉中斷,這時(shí)如果中斷處理程序執(zhí)行時(shí)間過(guò)長(zhǎng),可能在還未執(zhí)行完中斷處理程序前,會(huì)丟失當(dāng)前其他設(shè)備的中斷請(qǐng)求。

那 Linux 系統(tǒng)為了解決中斷處理程序執(zhí)行過(guò)長(zhǎng)和中斷丟失的問(wèn)題,將中斷過(guò)程分成了兩個(gè)階段,分別是「上半部和下半部分」。

  • 上半部用來(lái)快速處理中斷,一般會(huì)暫時(shí)關(guān)閉中斷請(qǐng)求,主要負(fù)責(zé)處理跟硬件緊密相關(guān)或者時(shí)間敏感的事情。

  • 下半部用來(lái)延遲處理上半部未完成的工作,一般以「內(nèi)核線程」的方式運(yùn)行。

前面的外賣例子,由于第一個(gè)配送員長(zhǎng)時(shí)間跟我通話,則導(dǎo)致第二位配送員無(wú)法撥通我的電話,其實(shí)當(dāng)我接到第一位配送員的電話,可以告訴配送員說(shuō)我現(xiàn)在下樓,剩下的事情,等我們見(jiàn)面再說(shuō)(上半部),然后就可以掛斷電話,到樓下后,在拿外賣,以及跟配送員說(shuō)其他的事情(下半部)。

這樣,第一位配送員就不會(huì)占用我手機(jī)太多時(shí)間,當(dāng)?shù)诙慌渌蛦T正好過(guò)來(lái)時(shí),會(huì)有很大幾率撥通我的電話。

再舉一個(gè)計(jì)算機(jī)中的例子,常見(jiàn)的網(wǎng)卡接收網(wǎng)絡(luò)包的例子。

網(wǎng)卡收到網(wǎng)絡(luò)包后,會(huì)通過(guò)硬件中斷通知內(nèi)核有新的數(shù)據(jù)到了,于是內(nèi)核就會(huì)調(diào)用對(duì)應(yīng)的中斷處理程序來(lái)響應(yīng)該事件,這個(gè)事件的處理也是會(huì)分成上半部和下半部。

上部分要做到快速處理,所以只要把網(wǎng)卡的數(shù)據(jù)讀到內(nèi)存中,然后更新一下硬件寄存器的狀態(tài),比如把狀態(tài)更新為表示數(shù)據(jù)已經(jīng)讀到內(nèi)存中的狀態(tài)值。

接著,內(nèi)核會(huì)觸發(fā)一個(gè)軟中斷,把一些處理比較耗時(shí)且復(fù)雜的事情,交給「軟中斷處理程序」去做,也就是中斷的下半部,其主要是需要從內(nèi)存中找到網(wǎng)絡(luò)數(shù)據(jù),再按照網(wǎng)絡(luò)協(xié)議棧,對(duì)網(wǎng)絡(luò)數(shù)據(jù)進(jìn)行逐層解析和處理,最后把數(shù)據(jù)送給應(yīng)用程序。

所以,中斷處理程序的上部分和下半部可以理解為:

  • 上半部直接處理硬件請(qǐng)求,也就是硬中斷,主要是負(fù)責(zé)耗時(shí)短的工作,特點(diǎn)是快速執(zhí)行;

  • 下半部是由內(nèi)核觸發(fā),也就說(shuō)軟中斷,主要是負(fù)責(zé)上半部未完成的工作,通常都是耗時(shí)比較長(zhǎng)的事情,特點(diǎn)是延遲執(zhí)行;

還有一個(gè)區(qū)別,硬中斷(上半部)是會(huì)打斷 CPU 正在執(zhí)行的任務(wù),然后立即執(zhí)行中斷處理程序,而軟中斷(下半部)是以內(nèi)核線程的方式執(zhí)行,并且每一個(gè) CPU 都對(duì)應(yīng)一個(gè)軟中斷內(nèi)核線程,名字通常為「ksoftirqd/CPU 編號(hào)」,比如 0 號(hào) CPU 對(duì)應(yīng)的軟中斷內(nèi)核線程的名字是 ksoftirqd/0

不過(guò),軟中斷不只是包括硬件設(shè)備中斷處理程序的下半部,一些內(nèi)核自定義事件也屬于軟中斷,比如內(nèi)核調(diào)度等、RCU 鎖(內(nèi)核里常用的一種鎖)等。


系統(tǒng)里有哪些軟中斷?

在 Linux 系統(tǒng)里,我們可以通過(guò)查看 /proc/softirqs 的 內(nèi)容來(lái)知曉「軟中斷」的運(yùn)行情況,以及 /proc/interrupts 的 內(nèi)容來(lái)知曉「硬中斷」的運(yùn)行情況。

接下來(lái),就來(lái)簡(jiǎn)單的解析下 ?/proc/softirqs 文件的內(nèi)容,在我服務(wù)器上查看到的文件內(nèi)容如下:

你可以看到,每一個(gè) CPU 都有自己對(duì)應(yīng)的不同類型軟中斷的累計(jì)運(yùn)行次數(shù),有 3 點(diǎn)需要注意下。

第一點(diǎn),要注意第一列的內(nèi)容,它是代表著軟中斷的類型,在我的系統(tǒng)里,軟中斷包括了 10 個(gè)類型,分別對(duì)應(yīng)不同的工作類型,比如 NET_TX 表示網(wǎng)絡(luò)接收中斷,NET_RX 表示網(wǎng)絡(luò)發(fā)送中斷、TIMER 表示定時(shí)中斷、RCU 表示 RCU 鎖中斷、SCHED 表示內(nèi)核調(diào)度中斷。

第二點(diǎn),要注意同一種類型的軟中斷在不同 CPU 的分布情況,正常情況下,同一種中斷在不同 CPU 上的累計(jì)次數(shù)相差不多,比如我的系統(tǒng)里,NET_RX 在 CPU0 、CPU1、CPU2、CPU3 上的中斷次數(shù)基本是同一個(gè)數(shù)量級(jí),相差不多。

第三點(diǎn),這些數(shù)值是系統(tǒng)運(yùn)行以來(lái)的累計(jì)中斷次數(shù),數(shù)值的大小沒(méi)什么參考意義,但是系統(tǒng)的中斷次數(shù)的變化速率才是我們要關(guān)注的,我們可以使用 watch -d cat /proc/softirqs 命令查看中斷次數(shù)的變化速率。

前面提到過(guò),軟中斷是以內(nèi)核線程的方式執(zhí)行的,我們可以用 ps 命令可以查看到,下面這個(gè)就是在我的服務(wù)器上查到軟中斷內(nèi)核線程的結(jié)果:

可以發(fā)現(xiàn),內(nèi)核線程的名字外面都有有中括號(hào),這說(shuō)明 ps 無(wú)法獲取它們的命令行參數(shù),所以一般來(lái)說(shuō),名字在中括號(hào)里到,都可以認(rèn)為是內(nèi)核線程。

而且,你可以看到有 4 個(gè) ksoftirqd 內(nèi)核線程,這是因?yàn)槲疫@臺(tái)服務(wù)器的 CPU 是 4 核心的,每個(gè) CPU 核心都對(duì)應(yīng)著一個(gè)內(nèi)核線程。


如何定位軟中斷 CPU 使用率過(guò)高的問(wèn)題?

要想知道當(dāng)前的系統(tǒng)的軟中斷情況,我們可以使用 top 命令查看,下面是一臺(tái)服務(wù)器上的 top 的數(shù)據(jù):

上圖中的黃色部分 si,就是 CPU 在軟中斷上的使用率,而且可以發(fā)現(xiàn),每個(gè) CPU 使用率都不高,兩個(gè) CPU 的使用率雖然只有 3% 和 4% 左右,但是都是用在軟中斷上了。

另外,也可以看到 CPU 使用率最高的進(jìn)程也是軟中斷 ksoftirqd,因此可以認(rèn)為此時(shí)系統(tǒng)的開銷主要來(lái)源于軟中斷。

如果要知道是哪種軟中斷類型導(dǎo)致的,我們可以使用 watch -d cat /proc/softirqs 命令查看每個(gè)軟中斷類型的中斷次數(shù)的變化速率。

一般對(duì)于網(wǎng)絡(luò) I/O 比較高的 Web 服務(wù)器,NET_RX 網(wǎng)絡(luò)接收中斷的變化速率相比其他中斷類型快很多。

如果發(fā)現(xiàn) NET_RX 網(wǎng)絡(luò)接收中斷次數(shù)的變化速率過(guò)快,接下里就可以使用 sar -n DEV 查看網(wǎng)卡的網(wǎng)絡(luò)包接收速率情況,然后分析是哪個(gè)網(wǎng)卡有大量的網(wǎng)絡(luò)包進(jìn)來(lái)。

接著,在通過(guò) tcpdump 抓包,分析這些包的來(lái)源,如果是非法的地址,可以考慮加防火墻,如果是正常流量,則要考慮硬件升級(jí)等。


總結(jié)

為了避免由于中斷處理程序執(zhí)行時(shí)間過(guò)長(zhǎng),而影響正常進(jìn)程的調(diào)度,Linux 將中斷處理程序分為上半部和下半部:

  • 上半部,對(duì)應(yīng)硬中斷,由硬件觸發(fā)中斷,用來(lái)快速處理中斷;

  • 下半部,對(duì)應(yīng)軟中斷,由內(nèi)核觸發(fā)中斷,用來(lái)異步處理上半部未完成的工作;

Linux 中的軟中斷包括網(wǎng)絡(luò)收發(fā)、定時(shí)、調(diào)度、RCU 鎖等各種類型,可以通過(guò)查看 /proc/softirqs 來(lái)觀察軟中斷的累計(jì)中斷次數(shù)情況,如果要實(shí)時(shí)查看中斷次數(shù)的變化率,可以使用 watch -d cat /proc/softirqs 命令。

每一個(gè) CPU 都有各自的軟中斷內(nèi)核線程,我們還可以用 ps 命令來(lái)查看內(nèi)核線程,一般名字在中括號(hào)里面到,都認(rèn)為是內(nèi)核線程。

如果在 top 命令發(fā)現(xiàn),CPU 在軟中斷上的使用率比較高,而且 CPU 使用率最高的進(jìn)程也是軟中斷 ksoftirqd 的時(shí)候,這種一般可以認(rèn)為系統(tǒng)的開銷被軟中斷占據(jù)了。

這時(shí)我們就可以分析是哪種軟中斷類型導(dǎo)致的,一般來(lái)說(shuō)都是因?yàn)榫W(wǎng)絡(luò)接收軟中斷導(dǎo)致的,如果是的話,可以用 sar 命令查看是哪個(gè)網(wǎng)卡的有大量的網(wǎng)絡(luò)包接收,再用 tcpdump 抓網(wǎng)絡(luò)包,做進(jìn)一步分析該網(wǎng)絡(luò)包的源頭是不是非法地址,如果是就需要考慮防火墻增加規(guī)則,如果不是,則考慮硬件升級(jí)等。


推薦閱讀

帶寬、延時(shí)、吞吐率、PPS 這些都是啥?

你不好奇 Linux 是如何收發(fā)網(wǎng)絡(luò)包的?


免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問(wèn)題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見(jiàn),不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉