成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

TCP/IP加速原理詳解

網絡 通信技術
由于網絡延遲的存在,對用戶體驗影響更大的是如何快速傳遞數據到客戶端,而這屬于流量優化的范疇。本文講述如何優化TCP性能和TCP數據傳遞。

請先看下這個case:

對某一個key value應用,從網卡接收數據包到應用層處理,再把數據發送出去,整個系統資源消耗情況如下:

TCP/IP加速原理詳解(干貨)

可以看出,Sockets接口+TCP是系統瓶頸。

根據下圖模型,瓶頸在于TCP(包括sockets接口)。

TCP/IP加速原理詳解(干貨)

要想提升系統吞吐量,必須要優化TCP。

由于網絡延遲的存在,對用戶體驗影響更大的是如何快速傳遞數據到客戶端,而這屬于流量優化的范疇。

本文講述如何優化TCP性能和TCP數據傳遞。

1. 什么是TCP加速

引用百度百科的定義:

TCP/IP加速原理詳解(干貨)

主流的TCP加速方式主要有 :基于流量的加速傳遞和數據包處理性能優化。

基于流量的方式主要通過修改擁塞控制算法來達到快速傳遞數據包的目的。

數據包處理性能優化包括內核優化、TCP offload和基于用戶態TCP協議的方式。這些方式可用于優化數據包處理,從而提升系統的吞吐量。

2. 基于流量的TCP加速方式

(1) TCP雙邊加速

TCP雙邊加速需要在TCP連接的兩端部署硬件設備或安裝軟件。

雙邊加速的優點是可以利用壓縮等技術進一步提升TCP傳輸效率,缺點是部署麻煩。

雙邊加速一般應用于公司不同分支之間的遠距離訪問。

下圖是雙邊加速的一個例子。TCP加速設備之間采用SCTP的協議進行交互,而原本TCP對端跟TCP加速設備之間則采用常規的TCP協議進行交互。這種透明代理的方式方便了TCP加速設備之間采用特殊的方式來加速。

TCP/IP加速原理詳解(干貨)

(2) 單邊加速

TCP單邊加速只需要在在TCP的一端部署軟件或設備,達到提升TCP快速傳輸數據的目的。

絕大部分TCP單邊加速都是通過修改TCP的擁塞控制算法來實現。

下圖顯示了某商用化產品的單邊加速情況,數據包的發送很暴力,并沒有慢啟動過程。這種無視網絡狀況發送數據包的方式,大部分場景下確實能夠提升性能,但這樣的性能提升方式其實是搶占了互聯網帶寬資源,就像高速公路走應急車道一樣。

TCP/IP加速原理詳解(干貨)

近幾年出現的google擁塞控制算法BBR可以看成是單邊加速的一種。

TCP/IP加速原理詳解(干貨)

上圖展示了相對于傳統擁塞控制算法CUBIC,BBR算法在網絡丟包情況下仍然表現優異,原因在于BBR算法摒棄丟包作為擁塞控制的直接反饋因素,通過實時計算帶寬和最小RTT來決定發送速率和窗口大小。

在移動應用場合,大部分網絡丟包并不是由于路由器網絡擁塞導致,因此在移動場合,BBR算法具有更好的適應性。

在Linux內核4.9以上版本(不包括docker環境),使用BBR算法,一般只需要在sysctl.conf文件加上下面兩句:

TCP/IP加速原理詳解(干貨)

然后執行sysctl -p使其生效。

TCP單邊加速的優點是只需要在一側進行部署,缺點是無法直接利用壓縮等功能,而且大都會破壞互聯網的公平性。

3. 內核優化

(1) 純內核優化

根據Wikipedia內容:

TCP/IP加速原理詳解(干貨)

我們得知,內核需要根據實際場景進行優化,不能一概而論。合理優化,可以提升性能很多(有時能夠提升10倍),但如果盲目優化,性能反而下降。

當今的內核,在大部分場景下,TCP buffer能夠自動調整buffer大小來匹配傳輸,所以在內核方面需要優化的地方就是選擇合適的擁塞控制算法。

下面是Linux默認算法CUBIC和BBR算法在丟包情況下的對比情況:

TCP/IP加速原理詳解(干貨)

在丟包情況下,BBR所受影響沒有Linux TCP默認算法CUBIC那么大,而且在20%以下的丟包率情況下性能遠超CUBIC。一般建議在非網絡擁塞導致丟包的場合使用BBR算法,例如移動應用。

對于帶寬比較大,RTT時間比較長的應用場景,可以參考。

(2) Dedicated fast path

由于內核處理TCP是通用的處理方式,不同的場景,執行的路徑是不一樣的,針對某些場景做特殊的優化,可以大大提升TCP的處理性能。

這方面可以參考論文"TAS: TCP Accleration as an OS Service"。

4. TCP offload

內核消耗性能的地方主要有如下四個方面:

TCP/IP加速原理詳解(干貨)

目前TCP offload常用的功能是TCP/IP checksum offload和TCP segmentation offload,主要是解決上面第二個問題。

其它問題需要更加強大的網卡支持,這方面可以參考"https://www.dell.com/downloads/global/power/1q04-her.pdf"。

"TCP Offload Engines"論文中描述了網絡應用內存拷貝的情況,具體參考下圖。

TCP/IP加速原理詳解(干貨)

不管是發送路徑還是接收路徑,系統存在大量內存拷貝,直接影響了TCP/IP協議棧性能,可以利用TCP offload功能,NIC直接拷貝到應用的buffer中去,減少拷貝次數,從而提升性能。

TCP offload可能是未來的趨勢,部署方便,代價小,是非常值得關注的一個方向。

5. 用戶態TCP協議

用戶態的協議棧在下列場合比較有用:

TCP/IP加速原理詳解(干貨)

是否要采用用戶態TCP協議棧,可以參考"https://blog.cloudflare.com/why-we-use-the-linux-kernels-tcp-stack/".

6. 總結

TCP加速是一個很大的領域,這方面應用得好,可以極大提升程序的性能,因此性能優化不要忽視這方面內容。

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2017-06-22 09:02:40

TCPIP重組

2013-01-28 13:18:54

飛魚星路由器TCP

2014-09-22 09:15:03

TCPIP

2012-12-03 11:50:44

TCPIP網絡流量

2024-12-19 11:00:00

TCP網絡通信粘包

2009-06-26 10:42:32

Web加速谷歌

2010-06-19 13:32:36

TCP IP協議棧

2021-05-12 00:07:27

TCPIP協議

2010-01-19 21:49:46

2010-01-20 14:55:27

2021-07-30 20:24:24

CDN網絡架構

2014-10-15 09:14:24

IP

2020-04-10 08:55:26

TCPIPBBR算法

2019-07-01 08:51:49

TCPIPLinux

2019-04-08 08:44:10

TCPIP網絡協議

2010-09-27 13:35:43

TCP IP故障

2014-11-21 09:16:23

TCPIP

2013-10-25 09:32:52

OSI七層協議TCP協議

2010-09-08 15:11:36

TCP IP協議棧

2010-06-08 13:32:19

TCP IP協議基礎
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久久99精品免费观看 | 精品久久一区 | 欧美成人在线免费 | 亚洲a视频 | 婷婷中文在线 | 一区二区三区四区日韩 | 国产美女精品视频免费观看 | 日韩精品在线观看免费 | 亚洲网站在线 | 国产在线看片 | 久久久久久精 | 一区二区伦理电影 | av黄色在线| 欧美日韩亚洲视频 | 99reav| 欧美8一10sex性hd | 亚洲第一视频网 | 欧美激情久久久 | 久久精品无码一区二区三区 | 欧美成人免费电影 | 亚洲日日 | 精品在线看 | 成人影视网 | www.男人天堂.com | 国产美女一区二区 | 天天搞天天搞 | 黄色免费三级 | 精品一区二区三区四区五区 | 亚洲精品日韩精品 | 久久蜜桃av一区二区天堂 | 一区二区三区四区国产 | 亚洲精品成人av久久 | 一区二区播放 | 91黄色片免费看 | 夜夜夜久久 | 中文字幕乱码一区二区三区 | 亚洲国产精品久久久 | 欧美网址在线观看 | 黄视频免费 | 日韩欧美综合在线视频 | 久久久免费观看视频 |