欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

怎么用DPDKGRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能

怎么用DPDK GRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能,相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

創(chuàng)新互聯(lián)建站堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的金灣網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

目前,有大量的網(wǎng)絡(luò)應(yīng)用在處理數(shù)據(jù)包的時(shí)候只需要處理數(shù)據(jù)包頭,而不會(huì)操作數(shù)據(jù)負(fù)載部分,例如防火墻、TCP/IP協(xié)議棧和軟件交換機(jī)。對(duì)這類網(wǎng)絡(luò)應(yīng)用而言, 包頭處理產(chǎn)生的開銷(稱為“per-packet overhead”)占了整體開銷的大部分。因此,如何減少包頭處理開銷是優(yōu)化這類應(yīng)用性能的關(guān)鍵。

減少包頭處理開銷最直接的方法:減少數(shù)據(jù)包數(shù)量

  如何減少包數(shù)量?

●增大Maximum Transmission Unit (MTU)。在數(shù)據(jù)量一定的情況下,使用大MTU的數(shù)據(jù)包可攜帶更多數(shù)據(jù),從而減少了包的總量。但MTU值依賴于物理鏈路,我們無(wú)法保證數(shù)據(jù)包經(jīng)過(guò)的所有鏈路均使用大MTU。

●利用網(wǎng)卡特性:Large Receive Offload (LRO),UDP Fragmentation Offload (UFO)和TCP Segmentation Offload (TSO)。如圖1所示,LRO將從物理鏈路收到的TCP包(如1500B)合并為長(zhǎng)度更長(zhǎng)的TCP包(如64KB);UFO和TSO將上層應(yīng)用發(fā)送的長(zhǎng)數(shù)據(jù)負(fù)載的UDP和TCP包(如64KB)拆分成長(zhǎng)度更短的數(shù)據(jù)包(如1500B),以滿足物理鏈路的MTU限制。通過(guò)在網(wǎng)卡上進(jìn)行包合并和拆分,在不需要任何CPU開銷的情況下,上層應(yīng)用就可以處理數(shù)量大大減少的大包。然而,LRO、TSO和UFO通常只能處理TCP和UDP包,而且并非所有的網(wǎng)卡都支持這些特性。

●軟件包合并 (Generic Receive Offload,GRO)和包拆分 (Generic Segmentation Offload,GSO)。與前兩種方法相比,GRO和GSO有兩個(gè)優(yōu)點(diǎn):第一,不依賴于物理鏈路和網(wǎng)卡;第二,能夠支持更多的協(xié)議類型,如VxLAN和GRE。

怎么用DPDK GRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能

圖1. LRO、UFO和TSO工作原理

為了幫助基于DPDK的應(yīng)用程序(如Open vSwitch)減少包頭處理開銷,DPDK分別于17.08和17.11支持了GRO和GSO。如圖2所示, GRO和GSO是DPDK中的兩個(gè)用戶庫(kù),應(yīng)用程序直接調(diào)用它們進(jìn)行包合并和分片。

怎么用DPDK GRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能

圖2. DPDK GRO和DPDK GSO

1、GRO庫(kù)和GSO庫(kù)結(jié)構(gòu)

圖3描繪了GRO庫(kù)和GSO庫(kù)的結(jié)構(gòu)。根據(jù)數(shù)據(jù)包類型,GRO庫(kù)定義了不同的GRO類型。每一種GRO類型負(fù)責(zé)合并一種類型的數(shù)據(jù)包,如TCP/IPv4 GRO處理TCP/IPv4數(shù)據(jù)包。同樣的,GSO庫(kù)也定義了不同的GSO類型。GRO庫(kù)和GSO庫(kù)分別根據(jù)MBUF的packet_type域和ol_flags域?qū)⑤斎氲臄?shù)據(jù)包交給對(duì)應(yīng)的GRO和GSO類型處理。

怎么用DPDK GRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能

圖3. GRO庫(kù)和GSO庫(kù)的框架

2、如何使用GRO庫(kù)和GSO庫(kù)?

使用GRO和GSO庫(kù)十分簡(jiǎn)單。如圖4所示,只需要調(diào)用一個(gè)函數(shù)便可以對(duì)包進(jìn)行合并和分片。

怎么用DPDK GRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能

圖4. 代碼示例

為了支持不同的用戶場(chǎng)景,GRO庫(kù)提供了兩組API:輕量模式API和重量模式API,如圖5所示。輕量模式API應(yīng)用于需要快速合并少量數(shù)據(jù)包的場(chǎng)景,而重量模式API則用于需要細(xì)粒度地控制合包并需要合并大量數(shù)據(jù)包的場(chǎng)景。

怎么用DPDK GRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能

圖5. 輕量模式API和重量模式API

 3、DPDK GRO的合包算法

算法挑戰(zhàn)

●在高速的網(wǎng)絡(luò)環(huán)境下,高開銷的合包算法很可能會(huì)導(dǎo)致網(wǎng)卡丟包。

●包亂序(“Packet Reordering”)增加了合包難度。例如Linux GRO無(wú)法合并亂序的數(shù)據(jù)包。

這就要求DPDK GRO的合包算法:

足夠輕量以適應(yīng)高速的網(wǎng)絡(luò)環(huán)境

能夠合并亂序包

基于Key的合包算法

為解決上述兩點(diǎn)挑戰(zhàn),DPDK GRO采用基于Key的合包算法,其流程如圖6所示。對(duì)新到的數(shù)據(jù)包,首先按照流(“flow”)對(duì)其進(jìn)行分類,再在其所在的流中尋找相鄰的數(shù)據(jù)包(“neighbor”)進(jìn)行合并。若無(wú)法找到匹配的流,就插入一條新流并將數(shù)據(jù)包存儲(chǔ)到新流中。若無(wú)法找到鄰居,則將數(shù)據(jù)包存儲(chǔ)到對(duì)應(yīng)的流中。

基于Key的合包算法有兩個(gè)特點(diǎn)。首先,通過(guò)流分類來(lái)加速數(shù)據(jù)包的合并是十分輕量的一種做法;其次,保存無(wú)法合并的數(shù)據(jù)包(如亂序包)使得之后對(duì)其進(jìn)行合并成為可能,故減輕了包亂序?qū)习鼛?lái)的影響。

怎么用DPDK GRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能

圖6. 基于Key的合包算法流程

 4、DPDK GSO的分片策略

分片流程

如圖7所示,將一個(gè)數(shù)據(jù)包分片有3個(gè)步驟。首先,將包的數(shù)據(jù)負(fù)載分成許多長(zhǎng)度更小的部分;其次,為每一個(gè)數(shù)據(jù)負(fù)載部分添加包頭(新形成的數(shù)據(jù)包稱為GSO Segment);最后,為每個(gè)GSO segment更新包頭(如TCP Sequence Number)。

怎么用DPDK GRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能

圖7. GSO分片流程

 GSO Segment的結(jié)構(gòu)

生成一個(gè)GSO Segment的最簡(jiǎn)單方法就是拷貝包頭和數(shù)據(jù)負(fù)載部分。但頻繁的數(shù)據(jù)拷貝會(huì)降低GSO性能,因此,DPDK GSO采用了一種基于零拷貝的數(shù)據(jù)結(jié)構(gòu)——Two-part MBUF——來(lái)組織GSO Segment。如圖8所示,一個(gè)Two-part MBUF由一個(gè)Direct MBUF和多個(gè)Indirect MBUF組成。Direct MBUF用來(lái)存儲(chǔ)包頭,Indirect MBUF則類似于指針,指向數(shù)據(jù)負(fù)載部分。利用Two-part MBUF,生成一個(gè)GSO Segment僅需拷貝長(zhǎng)度較短的包頭,而不需要拷貝較長(zhǎng)的數(shù)據(jù)負(fù)載部分。

怎么用DPDK GRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能

圖8. Two-part MBUF的結(jié)構(gòu)

GRO庫(kù)和GSO庫(kù)的狀態(tài)

目前,GRO庫(kù)還處于一個(gè)初期階段,僅對(duì)使用最廣泛的TCP/IPv4數(shù)據(jù)包提供了合包支持。GSO庫(kù)則支持更豐富的包類型,包括TCP/IPv4、VxLAN和GRE。

看完上述內(nèi)容,你們掌握怎么用DPDK GRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

新聞標(biāo)題:怎么用DPDKGRO和GSO來(lái)提高網(wǎng)絡(luò)應(yīng)用性能
鏈接URL:http://aaarwkj.com/article34/iipgpe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)、服務(wù)器托管、App開發(fā)、動(dòng)態(tài)網(wǎng)站、網(wǎng)站建設(shè)、電子商務(wù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)
香蕉久草官网视频观看| 2020年最新国产三级网站| 久娜娜精品视频在线观看| 久久国产精品99久久久| 国产一级二级三级大胆视频| 亚洲欧美激情国产综合久久| 亚洲一区二区三区精品乱码| 一区二区三区在线观看淫| 国产一区二区三区免费有码视频| 中文字幕av在线有码| 91九色国产老熟女乱子| 久久熟妇少妇亚洲精品| 厕所偷拍视频一区二区三区| 蜜臀av首页在线观看| 在线观看91高清视频| 久久女同互慰一区二区三区| 91日本精品免费在线视频| 亚洲一区二区日韩在线| 91在线视频国产网站| 日本在线精品在线观看| 亚洲综合另类视频在线观看 | 白白日韩欧美在线视频| 亚洲伊人av第一页在线观看| 亚洲国产中文日韩欧美在线| 在线青青草视频免费观看| 婷婷中文字幕在线不卡视频| 欧美成人精品欧美一级乱| 国产白丝免费在线观看| 日韩国产欧美亚洲一区不卡| 久久综合视频大片视频| 在线看日本十八禁网站| 永久免费看黄在线观看| 国产精品三级一区二区三区| 免费爱爱视频在线观看| 美女在线视频一区二区三区| 精品国产自在现线拍手机| 国产高清视频成人在线观看| 最近av中文字幕电影| 欧美日韩黄色人人小视频| 日本不卡一二三区在线观看| 日韩x级av免费在线观看|