www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 公眾號精選 > 架構(gòu)師社區(qū)
[導讀]我是一個網(wǎng)絡監(jiān)控軟件,我被開發(fā)出來的使命就是監(jiān)控網(wǎng)絡中進進出出的所有通信流量。一直以來,我的工作都非常的出色,但是隨著我監(jiān)控的網(wǎng)絡越來越龐大,網(wǎng)絡中的通信流量也變得越來越多,我開始有些忙不過來了,逐漸發(fā)生丟包的現(xiàn)象,而且最近這一現(xiàn)象越發(fā)的嚴重了。

我是一個網(wǎng)絡監(jiān)控軟件,我被開發(fā)出來的使命就是監(jiān)控網(wǎng)絡中進進出出的所有通信流量。

一直以來,我的工作都非常的出色,但是隨著我監(jiān)控的網(wǎng)絡越來越龐大,網(wǎng)絡中的通信流量也變得越來越多,我開始有些忙不過來了,逐漸發(fā)生丟包的現(xiàn)象,而且最近這一現(xiàn)象越發(fā)的嚴重了。

五分鐘看懂抓包神技:DPDK

萬兆流量需求

一天晚上,程序員哥哥把我從硬盤上叫了起來。

“這都幾點了,你怎么還不下班啊?”,我問小哥哥。

“哎,產(chǎn)品經(jīng)理說了,讓我下個月必須支持萬兆網(wǎng)絡流量的分析,我這壓力可大了,沒辦法只好加班了。”,說完整理了一下自己那日益稀疏的頭發(fā)。

五分鐘看懂抓包神技:DPDK

“萬兆?10Gbps?開玩笑呢吧?這是要累死我的節(jié)奏啊”

“可不是嗎,可愁死我了。你快給我說說,你工作這么久了,有沒有干的不爽的或者覺得可以改進的地方都可以給我說說”,小哥哥真誠的看著我。

我思考了片刻說到:“要說干的不爽的,還真有!就是我現(xiàn)在花了太多時間在拷貝數(shù)據(jù)包了,把數(shù)據(jù)包從內(nèi)核空間拷貝到用戶態(tài)空間,以前數(shù)據(jù)量小還行,現(xiàn)在網(wǎng)絡流量這么大,可真是要了我的老命了。”

小哥哥嘆了口氣,“哎,這個改不了,數(shù)據(jù)包是通過操作系統(tǒng)的API獲取的,操作系統(tǒng)又是從網(wǎng)卡那里讀取的,咱們是工作在用戶空間的程序,必須要拷貝一次,這沒辦法。你再想想別的?”

我也嘆了口氣,“那行吧,還有一個槽點,數(shù)據(jù)包收到后能不能直接交給我,別交給系統(tǒng)的協(xié)議棧netfilter框架他們?nèi)ヌ幚砹?,反正我拿來后也要重新分析,每次都從他們那里過一次,他們辦事效率又低,這不拖累我的工作嘛”

五分鐘看懂抓包神技:DPDK

小哥哥皺著眉頭,眨了眨眼睛說到:“大兄弟,這個咱也改不了啊,我這水平也有限,我還沒有能力改造你繞過操作系統(tǒng)讓你直接去跟網(wǎng)卡打交道啊。要不,要不你再說一個?嘿嘿”

“好吧,我也就不為難你了。有個簡單的問題,你可得改一下”

“什么問題,說說看?”

“就是我現(xiàn)在花了很多時間在線程切換上,等到再次獲得調(diào)度執(zhí)行后,經(jīng)常發(fā)現(xiàn)換了一個CPU核,導致之前的緩存都失效了,得重新建立緩存,這又是一個很大的浪費啊!能不能讓我的工作線程獨占CPU的核心,這樣我肯定能提高不少工作效率!”

五分鐘看懂抓包神技:DPDK

小哥哥稍微思考了一下,說到:“沒問題,這個可以有!用線程親和性就可以搞定,給你劃幾個核出來,不讓它們參與系統(tǒng)的線程調(diào)度分配,專門給你用,這事就包在我身上吧!”

中斷問題

過了幾天,程序員哥哥對我進行了升級改造,讓我的幾個工作線程都能獨占CPU核,工作效率提升了不少。

不過,距離產(chǎn)品經(jīng)理要求的萬兆流量分析指標,那還是差了一大截。

一天晚上,程序員小哥哥又找我聊了起來。

“現(xiàn)在分析能力確實有所提升,不過離目標還差得遠啊,你快給我說說,還有沒有改進的建議給我啊?”

“有倒是有,但是我估計你還是會說改不了”,我翻了個白眼。

“你先說說看嘛!”

“現(xiàn)在這個數(shù)據(jù)包是用中斷的形式來通知讀取的,能不能不用中斷,讓我自己去取???你是不知道,每次中斷都要保存上下文,從用戶態(tài)切換到內(nèi)核態(tài),那么多流量,這開銷大了去了!”,我激動的說到。

五分鐘看懂抓包神技:DPDK

小哥哥聽完沉默了。

“看吧,我就說你改不了吧!還是算了吧,趁早給產(chǎn)品經(jīng)理說這個需求做不了,咱倆都輕松自在”

“那不行,這個項目對我非常重要,我還指望通過你來升職加薪,走向人生巔峰呢!”,小哥哥說的很堅定。

“實在不行,那就多找?guī)着_機器,把我copy幾份過去,軟件不行就靠硬件堆出性能嘛!”,我沖他眨了個眼睛。

“這還用你說,老板肯定不會同意的”

“那我沒轍了,實話告訴你吧,想要我能處理萬兆網(wǎng)絡流量,非得繞開操作系統(tǒng),我親自去從網(wǎng)卡讀取數(shù)據(jù)包不可,你好好去研究下吧,想升職加薪,怎么能怕難呢!”,我給小哥哥打了打氣。

小哥哥點了點頭,“你說的是,我一定可以的,給我一點時間”

DPDK

就這樣過了一個多星期,程序員小哥哥一直沒再來找過我,也不知道他研究的怎么樣了。

又過了好幾天,他終于又來了。

“快出來!我找到辦法了,明天就開始改造你!”

我一聽來了興趣,“什么辦法?你打算怎么改造我?”

“這個新方案可以解決你之前提出的所有問題,可以讓你直接去跟網(wǎng)卡打交道,不用中斷來通知讀取數(shù)據(jù)包,也不用再把數(shù)據(jù)包交給系統(tǒng)協(xié)議棧和netfilter框架處理,不用再頻繁的在用戶態(tài)和內(nèi)核態(tài)反復切換了!”,小哥哥越說越激動!

“你也太牛了吧,能把這些問題都解決了!你是怎么做到這些的,什么原理?”,我好奇的問到。

小哥哥有些不好意思,“我哪有那本事啊,其實這是別人開發(fā)的技術,我只是拿來用而已。”

“額,那你都弄清楚它的原理了嗎,別到時候坑我?。 ?,我有些不太放心。

“這個你放心,這個技術叫DPDK,是人家Intel開發(fā)的技術,靠譜!”

接下來,程序員小哥哥給我介紹了這個叫DPDK的技術原理。

五分鐘看懂抓包神技:DPDK

有了DPDK,通過操作系統(tǒng)的用戶態(tài)模式驅(qū)動UIO,我可以在用戶態(tài)通過輪詢的方式讀取網(wǎng)卡的數(shù)據(jù)包,再也不用中斷了!

直接在用戶態(tài)讀取,再也不用把數(shù)據(jù)包在內(nèi)核態(tài)空間和用戶態(tài)空間搬來搬去。讀到了之后我直接就可以分析,還不用走系統(tǒng)協(xié)議棧和netfilter瞎耽誤功夫,簡直完美!

“還不止這些呢!還支持大頁內(nèi)存技術”,小哥哥得意的說到。

“大頁內(nèi)存?這是什么”

“默認情況下系統(tǒng)不是以4KB大小來管理內(nèi)存頁面的嗎?這個單位太小了,對于咱們服務器內(nèi)存會有大量的內(nèi)存頁面,為了管理這些頁面,就會有大量的頁表項。CPU里面進行內(nèi)存地址翻譯的緩存TLB大小有限,頁表項太多就會頻繁失效,降低內(nèi)存地址翻譯的速度!”

五分鐘看懂抓包神技:DPDK

聽到這里,我突然明白了:“我知道了,把這個單位調(diào)大,管理的內(nèi)存頁面就少了,頁表項數(shù)量就少了,TLB就不容易失效,地址翻譯就能更快對不對?”

“沒錯,你猜猜看,調(diào)到多大?”,小哥哥故作神秘。

“翻一倍,8KB?”,見小哥哥搖搖頭,我又猜到:“難道是16KB?”

“太保守了,能支持2MB和1GB兩種大小呢!”

“這么大,厲害了!”

空轉(zhuǎn)問題

第二天,程序員小哥哥開始了對我進行了徹底的重構(gòu)。

升級后的我試著跑了一下,發(fā)現(xiàn)了一個問題:如果數(shù)據(jù)包不是很多或者沒有數(shù)據(jù)包的情況下,我的輪詢基本上就挺浪費時間的,一直空轉(zhuǎn),由于我獨占了一個核,這個核的占用率就一直是100%,不少別的程序都吐槽我,占著**不**。

于是,程序員小哥哥又對我進行了升級,用上了Interrupt DPDK模式:沒有數(shù)據(jù)包處理時就進入睡眠,改為中斷通知。還可以和其他線程共享CPU核,不再獨占,但是DPDK線程會有更高調(diào)度優(yōu)先級,一旦數(shù)據(jù)包多了起來,我又變成輪詢模式,可以靈活切換。

程序員哥哥連續(xù)加了兩個星期的班,經(jīng)過一番優(yōu)化升級,我的數(shù)據(jù)包分析處理能力有了極大的提升。

然而遺憾的是,測試了幾輪,當面臨10Gbps的流量時,我還是有點力不從心,還是差了那么一點點。

小哥哥有些灰心喪氣,“我不知道該怎么辦了,你覺得還有什么哪些地方可以改進嗎?”

“我現(xiàn)在基本滿負荷工作了,應該沒有什么地方可以改進了?,F(xiàn)在唯一有時間喘口氣的地方就是數(shù)據(jù)競爭的時候了,遇到數(shù)據(jù)被加了鎖發(fā)生線程切換歇一歇”

小哥哥思考了幾秒鐘,突然眼睛一亮,高興的說到:“有了!”

還沒來得及問,就把我關閉,下班去了~

到底程序員小哥哥又要對我做什么呢?五分鐘看懂抓包神技:DPDK

特別推薦一個分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關注的小伙伴,可以長按關注一下:

五分鐘看懂抓包神技:DPDK

五分鐘看懂抓包神技:DPDK

五分鐘看懂抓包神技:DPDK

長按訂閱更多精彩▼

五分鐘看懂抓包神技:DPDK

如有收獲,點個在看,誠摯感謝

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

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉