日韩精品中文字幕一区二区-日韩精品中文字幕一区-日韩精品中文字幕视频-日韩精品在线一区二区三区-第一页在线-第一福利视频

當前位置:首頁文章首頁 IT學院 IT技術

nagle算法在網絡編程的作用

作者:  來源:  發布時間:2011-5-19 11:45:40  點擊:

TCP/IP協議中,無論發送多少數據,總是要在數據前面加上協議頭,同時,對方接收到數據,也需要發送ACK表示確認。為了盡可能的利用網絡帶寬,TCP總是希望盡可能的發送足夠大的數據。(一個連接會設置MSS參數,因此,TCP/IP希望每次都能夠以MSS尺寸的數據塊來發送數據)。

Nagle算法就是為了盡可能發送大塊數據,避免網絡中充斥著許多小數據塊。

Nagle算法的基本定義是任意時刻,最多只能有一個未被確認的小段。 所謂“小段”,指的是小于MSS尺寸的數據塊,所謂“未被確認”,是指一個數據塊發送出去后,沒有收到對方發送的ACK確認該數據已收到。

舉個例子,比如之前的blog中的實驗,一開始client端調用socket的write操作將一個int型數據(稱為A塊)寫入到網絡中,由于此時連接是空閑的(也就是說還沒有未被確認的小段),因此這個int型數據會被馬上發送到server端,接著,client端又調用write操作寫入‘\r\n’(簡稱B塊),這個時候,A塊的ACK沒有返回,所以可以認為已經存在了一個未被確認的小段,所以B塊沒有立即被發送,一直等待A塊的ACK收到(大概40ms之后),B塊才被發送。整個過程如圖所示:

這里還隱藏了一個問題,就是A塊數據的ACK為什么40ms之后才收到?這是因為TCP/IP中不僅僅有nagle算法,還有一個ACK延遲機制 。當Server端收到數據之后,它并不會馬上向client端發送ACK,而是會將ACK的發送延遲一段時間(假設為t),它希望在t時間內server端會向client端發送應答數據,這樣ACK就能夠和應答數據一起發送,就像是應答數據捎帶著ACK過去。在我之前的時間中,t大概就是40ms。這就解釋了為什么'\r\n'(B塊)總是在A塊之后40ms才發出。

如果你覺著nagle算法太搗亂了,那么可以通過設置TCP_NODELAY將其禁用 。當然,更合理的方案還是應該使用一次大數據的寫操作,而不是多次小數據的寫操作。

文章評論

軟件按字母排列: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
主站蜘蛛池模板: 你是我的玫瑰花简谱| 梁祝吉他谱独奏完整| 女同视频在线观看| 复仇女王 电视剧| 戴安·梅尔| 搜狐首页网| 车震电影| 追捕电影完整版免费| 宋雨导师的真实身世| 白璐个人简介照片| 小出由华| 王音棋的个人简历| 大学生国防论文2000字| 女生被艹在线观看| 美人天下| 王渝萱林教授最经典的三个角色| 阿尔法变频器说明书| 老司机免费在线视频| 抖音电脑版| 阿芮尔·温特| 5一6岁脑筋急转弯大全及答案| 成人免费视频在线播放| 迷夜电影| 东方卫视在线观看| 电影哪吒闹海| 成毅最新电视剧赴山海免费看| after之后| 二年级上学期口算题| 李莉莉| 秀人网蜜桃社尤果网| 日本电车系列| 美女网站视频免费| 古铜| 挠丝袜| 徐若| 陈学冬颖儿主演电视剧《解密》| 转正意见评语| 日韩欧美电影网| 天涯海角论坛官网登录入口| 十一码复式22块钱中奖对照表| 100条谐音歇后语|