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

牽著老婆滿街逛

嚴(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é)議,每個機(jī)制在帶來優(yōu)勢的同時也會引入其他的問題。 Nagel算法和delay ack機(jī)制是減少發(fā)送端和接收端包量的兩個機(jī)制, 可以有效減少網(wǎng)絡(luò)包量,避免擁塞。但是,在特定場景下, Nagel算法要求網(wǎng)絡(luò)中只有一個未確認(rèn)的包, 而delay ack機(jī)制需要等待更多的數(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ī)制, 已經(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機(jī)制, 上面的交互如下圖所示, 由于每次發(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>
            aⅴ色国产欧美| 久久人人爽人人爽爽久久| 国产亚洲欧美日韩精品| 欧美韩日亚洲| 久久国产夜色精品鲁鲁99| 亚洲精品视频免费观看| 久热精品在线视频| 亚洲欧美在线一区| av成人黄色| 亚洲精品1234| 影音国产精品| 国产亚洲亚洲| 国产精品欧美日韩一区| 欧美精品成人| 欧美高清成人| 免费一区二区三区| 久久久99爱| 欧美一区二区在线免费播放| 一本色道久久综合亚洲精品按摩| 欧美激情一区三区| 欧美本精品男人aⅴ天堂| 久久久www成人免费无遮挡大片 | 久久久精品欧美丰满| 亚洲欧美日韩精品| 一区二区日韩免费看| 91久久精品国产91久久| 亚洲电影av在线| 伊人色综合久久天天| 国产亚洲成人一区| 国产网站欧美日韩免费精品在线观看| 国产精品久久久久久久app| 欧美日韩一区二区三区在线看 | 国产一区二区三区四区| 国产区精品视频| 国产情侣久久| 国产一区日韩欧美| 国产一区二区高清| 狠狠色狠狠色综合日日91app| 国产精品一区二区黑丝| 国产女主播在线一区二区| 国产乱码精品1区2区3区| 国产免费成人| 国产自产女人91一区在线观看| 国产亚洲人成a一在线v站| 国产专区欧美专区| 国产女人水真多18毛片18精品视频| 欧美日韩和欧美的一区二区| 欧美涩涩视频| 国产欧美日韩精品丝袜高跟鞋| 国产亚洲欧美一区在线观看| 好男人免费精品视频| 亚洲国产精品久久精品怡红院| 亚洲高清视频中文字幕| 99re66热这里只有精品3直播| 日韩亚洲在线| 香蕉av福利精品导航| 久久精品国语| 亚洲高清在线观看| 亚洲理伦在线| 99精品热视频只有精品10| 亚洲一品av免费观看| 久久精品一区二区三区不卡| 免费观看成人网| 欧美偷拍一区二区| 国内成人精品视频| 亚洲精品国久久99热| 亚洲一区免费看| 久久久久久久久久久久久久一区 | 亚洲欧美中文日韩在线| 久久久久久黄| 欧美日韩精品免费| 国内外成人免费激情在线视频| 在线免费观看视频一区| 亚洲图片欧美日产| 久久久一二三| 亚洲伦理久久| 欧美一级成年大片在线观看| 欧美暴力喷水在线| 国产日韩欧美91| 99riav1国产精品视频| 性娇小13――14欧美| 欧美激情一区二区三区高清视频 | 欧美成人在线免费视频| 国产女主播在线一区二区| 亚洲激情电影中文字幕| 亚洲欧美综合一区| 欧美激情第9页| 亚洲欧美日产图| 欧美国产视频日韩| 好吊视频一区二区三区四区| 中文精品视频| 久久久www| 亚洲一区久久| 欧美精品一区二区三区视频| 国产一区在线看| 亚洲午夜精品久久久久久app| 久久手机免费观看| 亚洲一区综合| 欧美日韩精品免费观看视频| 精品91在线| 欧美一区二区黄色| 日韩亚洲不卡在线| 欧美gay视频| 国内精品视频在线播放| 午夜精品在线观看| 亚洲美女av网站| 蜜月aⅴ免费一区二区三区| 国产欧美亚洲日本| 午夜久久电影网| 日韩一级黄色av| 欧美另类久久久品| 91久久国产精品91久久性色| 久久在线视频在线| 久久xxxx| 国产欧美亚洲精品| 先锋影音国产精品| 亚洲午夜av在线| 欧美视频日韩| 中文网丁香综合网| 最新亚洲电影| 欧美精品免费在线观看| 亚洲欧洲午夜| 欧美大片一区二区| 久久久久久噜噜噜久久久精品 | 欧美不卡视频| 久久精品视频在线播放| 国产香蕉久久精品综合网| 小嫩嫩精品导航| 亚洲综合色丁香婷婷六月图片| 国产精品高清免费在线观看| 亚洲影音先锋| 亚洲制服丝袜在线| 国产美女高潮久久白浆| 香蕉国产精品偷在线观看不卡| 中文国产成人精品| 国产精品视频xxxx| 久久精品国产999大香线蕉| 午夜日韩激情| 激情久久影院| 欧美激情视频一区二区三区免费| 久久综合色综合88| 亚洲日韩中文字幕在线播放| 毛片基地黄久久久久久天堂| 久久只有精品| 99国产一区| 在线视频免费在线观看一区二区| 欧美性猛交视频| 欧美一级理论性理论a| 欧美一区二区三区在线视频| 狠狠做深爱婷婷久久综合一区| 美国十次了思思久久精品导航| 久久久久久久久久码影片| 亚洲欧洲在线看| 亚洲第一精品久久忘忧草社区| 欧美片在线播放| 亚洲欧美成人| 久久精品国产一区二区三区免费看| 一区在线播放视频| 亚洲精品免费看| 国产伦精品免费视频| 狂野欧美激情性xxxx| 欧美国产日韩xxxxx| 午夜国产欧美理论在线播放| 亚洲欧美自拍偷拍| 亚洲国产成人不卡| 一本色道久久综合亚洲精品不| 国产女主播视频一区二区| 免费永久网站黄欧美| 欧美久久久久久久| 一区二区av| 国产伦精品一区二区三区视频黑人| 中文在线资源观看网站视频免费不卡 | 亚洲免费观看在线观看| 亚洲香蕉伊综合在人在线视看| 欧美一级免费视频| 亚洲国产视频一区二区| 欧美成人免费在线观看| 国产精品av免费在线观看| 午夜一区不卡| 久久精品日韩一区二区三区| 影音先锋在线一区| 欧美成人精精品一区二区频| 亚洲特级片在线| 国产欧美一区在线| 老司机67194精品线观看| 亚洲欧美国产三级| 性欧美大战久久久久久久免费观看| 久久男女视频| 亚洲网站啪啪| 亚洲影院色无极综合| 国产有码一区二区| 亚洲伦理精品| 亚洲福利小视频| 亚洲第一综合天堂另类专| 欧美天天综合网| 久久久久国产精品一区三寸| 一区免费在线| 狂野欧美激情性xxxx欧美| 亚洲国产高清高潮精品美女| 欧美日韩在线播放三区四区|