青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴(yán)以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

再說TCP神奇的40ms

轉(zhuǎn)載自:https://www.qcloud.com/community/article/186

TCP是一個復(fù)雜的協(xié)議,每個機制在帶來優(yōu)勢的同時也會引入其他的問題。 Nagel算法和delay ack機制是減少發(fā)送端和接收端包量的兩個機制, 可以有效減少網(wǎng)絡(luò)包量,避免擁塞。但是,在特定場景下, Nagel算法要求網(wǎng)絡(luò)中只有一個未確認(rèn)的包, 而delay ack機制需要等待更多的數(shù)據(jù)包, 再發(fā)送ACK回包, 導(dǎo)致發(fā)送和接收端等待對方發(fā)送數(shù)據(jù), 造成死鎖, 只有當(dāng)delay ack超時后才能解開死鎖,進(jìn)而導(dǎo)致應(yīng)用側(cè)對外的延時高。 其他文字已經(jīng)介紹了相關(guān)的機制, 已經(jīng)有一些文章介紹這種時延的場景。本文結(jié)合具體的tcpdump包,分析觸發(fā)delay ack的場景,相關(guān)的內(nèi)核參數(shù), 以及規(guī)避的方案。

背景

給redis加了一個proxy層, 壓測的時候發(fā)現(xiàn), 對寫入命令,數(shù)據(jù)長度大于2k后, 性能下降非常明顯, 只有直連redis-server的1/10. 而get請求影響并不是那么明顯。

分析

觀察系統(tǒng)的負(fù)載和網(wǎng)絡(luò)包量情況, 都比較低, 網(wǎng)絡(luò)包量也比較小, proxy內(nèi)部的耗時也比較短。 無賴只能祭出tcpdump神奇, 果然有妖邪。

22號tcp請求包, 42ms后服務(wù)端才返回了ack。 初步懷疑是網(wǎng)絡(luò)層的延時導(dǎo)致了耗時增加。Google和km上找資料, 大概的解釋是這樣: 由于客戶端打開了Nagel算法, 服務(wù)端未關(guān)閉延遲ack, 會導(dǎo)致延遲ack超時后,再發(fā)送ack,引起超時。

原理

Nagel算法,轉(zhuǎn)自維基百科

if there is new data to send if the window size >= MSS and available data is >= MSS send complete MSS segment now else if there is unconfirmed data still in the pipe enqueue data in the buffer until an acknowledge is received else send data immediately end if end if end if 

簡單講, Nagel算法的規(guī)則是:

  1. 如果發(fā)送內(nèi)容大于1個MSS, 立即發(fā)送;
  2. 如果之前沒有包未被確認(rèn), 立即發(fā)送;
  3. 如果之前有包未被確認(rèn), 緩存發(fā)送內(nèi)容;
  4. 如果收到ack, 立即發(fā)送緩存的內(nèi)容。

延遲ACK的源碼如下:net/ipv4/tcp_input.c

基本原理是:

  1. 如果收到的數(shù)據(jù)內(nèi)容大于一個MSS, 發(fā)送ACK;
  2. 如果收到了接收窗口以為的數(shù)據(jù), 發(fā)送ACK;
  3. 如果處于quick mode, 發(fā)送ACK;
  4. 如果收到亂序的數(shù)據(jù), 發(fā)送ACK;
  5. 其他, 延遲發(fā)送ACK

其他都比較明確, quick mode是怎么判斷的呢? 繼續(xù)往下看代碼:

影響quick mode的一個因素是 ping pong的狀態(tài)。 Pingpong是一個狀態(tài)值, 用來標(biāo)識當(dāng)前tcp交互的狀態(tài), 以預(yù)測是否是W-R-W-R-W-R這種交互式的通訊模式, 如果處于, 可以用延遲ack, 利用Read的回包, 將Write的回包, 捎帶給發(fā)送方。

如上圖所示, 默認(rèn)pingpong = 0, 表示非交互式的, 服務(wù)端收到數(shù)據(jù)后, 立即返回ACK, 當(dāng)服務(wù)端有數(shù)據(jù)響應(yīng)時,服務(wù)端將pingpong = 1, 以后的交互中, 服務(wù)端不會立即返回ack,而是等待有數(shù)據(jù)或者ACK超時后響應(yīng)。

問題

按照前面的的原理分析,應(yīng)該每次都有ACK延遲的,為什么我們測試小于2K的數(shù)據(jù)時, 性能并沒有受到影響呢?
繼續(xù)分析tcpdump包:

按照Nagel算法和延遲ACK機制, 上面的交互如下圖所示, 由于每次發(fā)生的數(shù)據(jù)都包含了完整的請求, 服務(wù)端處理完成后, 向客戶端返回命令響應(yīng)時, 將請求的ACK捎帶給客戶端,節(jié)約一次網(wǎng)絡(luò)包。

再分析2K的場景:

如下表所示, 第22個包發(fā)送的數(shù)據(jù)小于MSS, 同時,pingpong = 1, 被認(rèn)為是交互模式, 期待通過捎帶ACK的方式來減少網(wǎng)絡(luò)的包量。 但是, 服務(wù)端收到的數(shù)據(jù),并不是一個完整的包,不能產(chǎn)生一次應(yīng)答。服務(wù)端只能在等待40ms超時后,發(fā)送ACK響應(yīng)包。
同時,從客戶端來看,如果在發(fā)送一個包, 也可以打破已收數(shù)據(jù) > MSS的限制。 但是,客戶端受Nagel算法的限制, 一次只能有一個包未被確認(rèn),其他的數(shù)據(jù)只能被緩存起來, 等待發(fā)送。

觸發(fā)場景

一次tcp請求的數(shù)據(jù), 不能在服務(wù)端產(chǎn)生一次響應(yīng),或者小于一個MSS

規(guī)避方案

只有同時客戶端打開Nagel算法, 服務(wù)端打開tcp_delay_ack才會導(dǎo)致前面的死鎖狀態(tài)。 解決方案可以從TCP的兩端來入手。

服務(wù)端:

  1. 關(guān)閉tcp_delay_ack, 這樣, 每個tcp請求包都會有一個ack及時響應(yīng), 不會出現(xiàn)延遲的情況。 操作方式:
    echo 1 > /proc/sys/net/ipv4/tcp_no_delay_ack
    但是, 每個tcp請求都返回一個ack包, 導(dǎo)致網(wǎng)絡(luò)包量的增加,關(guān)閉tcp延遲確認(rèn)后, 網(wǎng)絡(luò)包量大概增加了80%,在高峰期影響還是比較明顯。
  2. 設(shè)置TCP_QUICKACK屬性。 但是需要每次recv后再設(shè)置一次。 對應(yīng)我們的場景不太適合,需要修改服務(wù)端redis源碼。

客戶端:

  1. 關(guān)閉nagel算法,即設(shè)置socket tcp_no_delay屬性。
    static void _set_tcp_nodelay(int fd) { int enable = 1; setsockopt(fd, IPPROTO_TCP, TCP_NODELAY, (void*)&enable, sizeof(enable)); } 
  2. 避免多次寫, 再讀取的場景, 合并成一個大包的寫;避免一次請求分成多個包發(fā)送, 最開始發(fā)送的包小于一個MSS,對我們的場景, 把第22號包的1424個字節(jié)緩存起來, 大于一個MSS的時候,再發(fā)送出去, 服務(wù)端立即返回響應(yīng), 客戶端繼續(xù)發(fā)送后續(xù)的數(shù)據(jù), 完成交互,避免時延。

參考資料:
http://jerrypeng.me/2013/08/mythical-40ms-delay-and-tcp-nodelay/
http://blog.163.com/xychenbaihu@yeah/blog/static/132229655201231214038740/
http://blog.chinaunix.net/uid-28387257-id-3658980.html
https://github.com/torvalds/linux/blob/master/net/ipv4/tcp_input.c

轉(zhuǎn)載請注明出處: 騰云閣 https://www.qcloud.com/community

posted on 2016-11-02 10:11 楊粼波 閱讀(928) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            伊人久久噜噜噜躁狠狠躁| 亚洲综合国产激情另类一区| 91久久嫩草影院一区二区| 猛干欧美女孩| 亚洲欧洲日夜超级视频| av成人免费在线| 国产精品久久久久天堂| 午夜精品影院在线观看| 欧美插天视频在线播放| 亚洲欧洲一区二区三区| 欧美视频三区在线播放| 篠田优中文在线播放第一区| 欧美成人官网二区| 亚洲一区二区在| 国产在线一区二区三区四区| 美女精品网站| 亚洲欧美www| 欧美国产视频日韩| 亚洲一区国产精品| 国内一区二区在线视频观看| 蜜臀91精品一区二区三区| 日韩亚洲在线观看| 卡通动漫国产精品| 亚洲一区网站| 亚洲国产高清一区| 国产精品久久久久影院色老大| 久久精品天堂| 在线视频欧美日韩| 欧美va亚洲va国产综合| 亚洲综合大片69999| 一区二区三区中文在线观看 | 免费久久久一本精品久久区| 亚洲免费观看视频| 久久综合色8888| 亚洲桃色在线一区| 亚洲人成网站999久久久综合| 国产精品久久久久久久久果冻传媒| 久久精品视频免费播放| 国产精品99久久久久久有的能看 | 欧美黄色影院| 欧美综合第一页| 宅男噜噜噜66一区二区66| 欧美搞黄网站| 久久噜噜亚洲综合| 午夜欧美精品| 亚洲婷婷在线| aa日韩免费精品视频一| 亚洲国产视频一区| 国内伊人久久久久久网站视频| 欧美午夜电影完整版| 欧美va亚洲va香蕉在线| 久久久精品国产免大香伊 | 午夜视频在线观看一区| 亚洲清纯自拍| 亚洲黄色小视频| 国产综合av| 国产啪精品视频| 国产精品视频一区二区高潮| 欧美日韩色一区| 欧美人在线视频| 欧美精品一区二区三区四区| 玖玖在线精品| 开元免费观看欧美电视剧网站| 欧美一区二区三区久久精品茉莉花| 一区二区欧美日韩视频| 亚洲精品综合精品自拍| 亚洲激情电影在线| 亚洲国产精品尤物yw在线观看| 欧美大秀在线观看| 欧美高潮视频| 欧美韩日视频| 亚洲人成在线观看一区二区| 亚洲大片精品永久免费| 亚洲国产精品成人| 亚洲日本aⅴ片在线观看香蕉| 亚洲电影一级黄| 最新国产拍偷乱拍精品| 亚洲电影免费观看高清完整版在线观看 | 久久久精品视频成人| 久久精品视频网| 狼人天天伊人久久| 欧美电影在线| 亚洲精品一区在线观看香蕉| 日韩视频一区二区在线观看| 亚洲美女少妇无套啪啪呻吟| 在线一区二区三区四区| 亚洲欧美久久久久一区二区三区| 欧美在线二区| 六月丁香综合| 欧美美女福利视频| 国产精品一区亚洲| 国语精品中文字幕| 亚洲精品影院| 亚洲欧美电影院| 久久亚洲色图| 91久久精品日日躁夜夜躁国产| 99国产一区| 欧美一区二区三区在线视频| 久久久久久久精| 欧美美女bbbb| 国产区精品在线观看| 极品尤物一区二区三区| 日韩视频一区| 久久se精品一区精品二区| 另类av导航| 日韩视频一区二区三区在线播放| 亚洲欧美色婷婷| 欧美1区2区3区| 国产精品一区二区男女羞羞无遮挡| 黑人巨大精品欧美一区二区| 亚洲精品一级| 久久九九热免费视频| 欧美国产第一页| 亚洲在线中文字幕| 欧美va亚洲va国产综合| 国产精品视频九色porn| 亚洲国产另类久久久精品极度 | 久久国产欧美精品| 亚洲国产视频a| 久久爱另类一区二区小说| 欧美另类综合| 影音先锋中文字幕一区| 亚洲一区二区三区激情| 免费观看亚洲视频大全| 宅男噜噜噜66一区二区66| 老司机免费视频一区二区| 国产精品麻豆va在线播放| 91久久国产综合久久91精品网站| 小黄鸭精品aⅴ导航网站入口| 亚洲电影毛片| 久久久精品tv| 国产农村妇女精品| 在线午夜精品| 亚洲国产精品一区二区www| 久久狠狠一本精品综合网| 国产精品日韩专区| 一区二区三区视频在线看| 免费亚洲婷婷| 欧美在线三区| 国产女精品视频网站免费| 日韩亚洲精品在线| 亚洲电影在线| 久久亚洲国产成人| 国产视频一区免费看| 亚洲一区二区三区四区中文 | 亚洲另类在线一区| 蜜桃av一区| 1000部国产精品成人观看| 欧美一区二区三区视频| 一本一道久久综合狠狠老精东影业 | 在线免费观看视频一区| 欧美在线免费观看| 亚洲制服欧美中文字幕中文字幕| 欧美日韩一区二区三| 夜夜嗨av色综合久久久综合网| 亚洲电影在线播放| 欧美成人dvd在线视频| 亚洲高清在线精品| 欧美国产精品劲爆| 玖玖综合伊人| 91久久久在线| 亚洲国产美女久久久久| 免费视频一区二区三区在线观看| 在线成人免费观看| 欧美成人一区二区三区| 久热综合在线亚洲精品| 亚洲国产中文字幕在线观看| 欧美成人高清| 欧美国产日韩一二三区| 亚洲久久成人| 99一区二区| 国产精品嫩草99a| 久久精品国产2020观看福利| 欧美一区三区三区高中清蜜桃| 国内久久精品| 欧美a级一区| 欧美美女日韩| 欧美亚洲午夜视频在线观看| 亚洲综合清纯丝袜自拍| 国产一区在线看| 女女同性精品视频| 欧美成人午夜激情| 亚洲一区二区视频| 亚洲欧美中文另类| 在线观看国产成人av片| 亚洲国产精品久久久久婷婷884| 欧美区一区二| 欧美一区二区三区四区高清| 欧美在线免费看| 亚洲黄一区二区| 一区二区三区四区五区在线| 国产精品性做久久久久久| 浪潮色综合久久天堂| 欧美激情综合色综合啪啪| 亚洲伊人网站| 久久久伊人欧美| 亚洲视频精选在线| 久久久国产精品一区| 一区二区三区四区蜜桃| 亚洲欧美第一页|