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

牽著老婆滿街逛

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

再說TCP神奇的40ms

轉載自:https://www.qcloud.com/community/article/186

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

背景

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

分析

觀察系統的負載和網絡包量情況, 都比較低, 網絡包量也比較小, proxy內部的耗時也比較短。 無賴只能祭出tcpdump神奇, 果然有妖邪。

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

原理

Nagel算法,轉自維基百科

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算法的規則是:

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

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

基本原理是:

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

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

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

如上圖所示, 默認pingpong = 0, 表示非交互式的, 服務端收到數據后, 立即返回ACK, 當服務端有數據響應時,服務端將pingpong = 1, 以后的交互中, 服務端不會立即返回ack,而是等待有數據或者ACK超時后響應。

問題

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

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

再分析2K的場景:

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

觸發場景

一次tcp請求的數據, 不能在服務端產生一次響應,或者小于一個MSS

規避方案

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

服務端:

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

客戶端:

  1. 關閉nagel算法,即設置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. 避免多次寫, 再讀取的場景, 合并成一個大包的寫;避免一次請求分成多個包發送, 最開始發送的包小于一個MSS,對我們的場景, 把第22號包的1424個字節緩存起來, 大于一個MSS的時候,再發送出去, 服務端立即返回響應, 客戶端繼續發送后續的數據, 完成交互,避免時延。

參考資料:
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

轉載請注明出處: 騰云閣 https://www.qcloud.com/community

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


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            一本色道**综合亚洲精品蜜桃冫 | 亚洲激情综合| 欧美aaaaaaaa牛牛影院| 亚洲国产日日夜夜| 久久国产精品久久精品国产| 亚洲一区二区三区欧美| 麻豆精品国产91久久久久久| 亚洲已满18点击进入久久| 国产一区99| 国产精品草莓在线免费观看| 久久一区二区三区四区五区| 亚洲在线观看免费视频| 欧美mv日韩mv亚洲| 欧美高清视频一区二区| 欧美一区二区视频观看视频| 日韩一级裸体免费视频| 国产午夜精品久久| 国产精品久久网| 午夜久久久久久久久久一区二区| 亚洲第一区中文99精品| 久久香蕉精品| 亚洲精品亚洲人成人网| 亚洲自拍电影| 欧美一区91| 久久久久久久999| av成人毛片| 在线日韩日本国产亚洲| 亚洲承认在线| 欧美日本三级| 国产欧美亚洲一区| 久久不射中文字幕| 亚洲精品久久久久久久久久久久 | 午夜精品久久一牛影视| 免费看黄裸体一级大秀欧美| 国内精品**久久毛片app| 亚洲欧美国产日韩中文字幕| 免费在线亚洲欧美| 欧美在线观看视频一区二区三区| 欧美私人网站| 亚洲美女视频在线免费观看| 麻豆精品国产91久久久久久| 亚洲一区欧美一区| 国产精品一区毛片| 久久精品国产免费观看| 午夜在线播放视频欧美| 国产精品久久久久aaaa九色| 亚洲一区视频| 欧美综合国产| 亚洲欧洲一二三| 亚洲国产专区| 欧美日韩在线观看一区二区| 亚洲天堂偷拍| 久久综合福利| 亚洲综合欧美日韩| 久久婷婷丁香| 中文在线资源观看视频网站免费不卡| 最近看过的日韩成人| 国产精品久久久久毛片软件 | 久久亚洲国产精品日日av夜夜| 翔田千里一区二区| 黄色一区二区三区| 一区二区三区亚洲| 一区二区三区国产精华| 在线视频一区观看| 国内伊人久久久久久网站视频 | 99精品视频免费全部在线| 亚洲精选中文字幕| 尤物九九久久国产精品的特点| 亚洲精品小视频| 亚洲电影天堂av| 久久精品官网| 欧美有码视频| 国产欧美精品日韩| 日韩午夜精品| 亚洲国产人成综合网站| 一区二区三区日韩欧美精品| 欧美一区在线看| 99精品国产高清一区二区| 猛男gaygay欧美视频| 国产日韩欧美高清| 欧美成人四级电影| 亚洲日本欧美天堂| 国产视频在线一区二区| 亚洲伊人一本大道中文字幕| 亚洲图色在线| 国产麻豆日韩| 久久久久久久网| 亚洲国产精品一区在线观看不卡 | 亚洲欧美日韩在线观看a三区| 日韩一级黄色大片| 欧美日韩视频专区在线播放 | 亚洲激情校园春色| 欧美精品在线免费| 亚洲综合首页| 欧美一级久久久久久久大片| 久久美女性网| aa级大片欧美| 美女亚洲精品| 亚洲欧美三级伦理| 这里只有精品视频| 欧美国产精品人人做人人爱| 日韩一级大片| 伊大人香蕉综合8在线视| 欧美激情一区二区三区成人| 亚洲在线观看| 日韩午夜视频在线观看| 欧美sm重口味系列视频在线观看| 99国产精品久久久久老师| 国产在线麻豆精品观看| 国产精品欧美日韩| 欧美色精品在线视频| 欧美国产欧美综合| 蜜桃av一区二区三区| 性久久久久久久久| 欧美一区二区三区四区夜夜大片| 亚洲人成毛片在线播放| 欧美韩日精品| 91久久精品国产91久久| 欧美激情va永久在线播放| 久久久www成人免费毛片麻豆| 久久久午夜视频| 欧美一区二区在线免费播放| 国产精品美女久久久| 亚洲永久免费av| 中文欧美日韩| 亚洲精品国产无天堂网2021| 久久久亚洲一区| 亚洲国产婷婷综合在线精品| 欧美激情五月| 欧美不卡在线视频| 欧美视频四区| 国产伪娘ts一区| 亚洲欧洲精品天堂一级| 中文日韩在线| 久久在线视频在线| 中文在线不卡视频| 久久国产一区| 欧美性久久久| 樱花yy私人影院亚洲| 亚洲一线二线三线久久久| 久久婷婷人人澡人人喊人人爽| 亚洲国产一区二区a毛片| 亚洲女人天堂av| 欧美精品久久久久久久久久| 国产欧美日韩不卡| 亚洲精品三级| 久久精品青青大伊人av| 亚洲久久一区| 欧美电影电视剧在线观看| 国产综合自拍| 欧美在线观看视频在线| 日韩亚洲视频| 欧美日韩精品免费观看视频完整| 母乳一区在线观看| 欧美中文在线观看国产| 国产精品三级视频| 欧美一区二区播放| 亚洲综合好骚| 国产私拍一区| 亚洲国产精品va在看黑人| 136国产福利精品导航| 久久婷婷av| 久久久爽爽爽美女图片| 午夜精品一区二区在线观看| 国产精品一区二区久久久| 久久er精品视频| 久久久久久亚洲精品中文字幕| 国产亚洲欧洲| 91久久久久久久久| 国产精品婷婷| 欧美国产亚洲精品久久久8v| 欧美久久视频| 久久精品一区二区三区不卡牛牛| 欧美亚洲三区| 一区二区三区欧美日韩| 午夜久久黄色| 日韩视频一区二区三区| 亚洲免费在线| 亚洲美女91| 久久久一区二区| 欧美一级在线视频| 欧美精品国产| 欧美激情偷拍| 亚洲成在人线av| 亚洲理论在线| 久久精品国产欧美激情| 亚洲一区二区视频在线| 蜜月aⅴ免费一区二区三区| 久久久青草青青国产亚洲免观| 欧美精品在线视频| 91久久精品国产91久久| 亚洲日韩欧美视频一区| 久久久午夜电影| 欧美电影免费观看大全| 黄色小说综合网站| 欧美一区日本一区韩国一区| 亚洲伊人网站| 国产欧美日韩免费看aⅴ视频| 亚洲视频1区| 久久久久一区二区三区|