TCP报文分段导致的数据重传

引言:不同厂家生产的不同型号的计算机,它们运行着不同的操作系统,但它们仍然可以相互通信,因为它们的网卡驱动程序都支持TCP/IP协议族。

一、TCP/IP协议模型

图一 TCP/IP协议模型

      TCP/IP协议族是一个四层的协议系统,它有很多种协议,其中tcp和udp是两个最重要的传输层协议,它们的都使用IP作为网络层协议,tcp虽然使用不可靠的IP服务,可它却提供了一种可靠的传输层服务,使用tcp协议的应用有telnet,ftp,smtp,http等;udp为应用程序发送和接收数据报,与tcp不同的是,udp是不可靠的,它无法保证数据能安全的到达目的地,使用udp协议的应用有tftp,snmp等;IP是网络层上主要的协议,同时被tcp和udp使用,tcp和ip的每组数据都通过端系统和每一个中间路由器中的IP层在网络中进行传输;ICMP是IP协议的附属协议,IP层用它来与其他主机或者路由器交换错误报文和其他重要信息,尽管icmp主要被IP使用,但应用程序也有可能访问它,使用icmp的应用程序主要有ping。IGMP是internet组管理协议,它用来把一个UDP数据报多播到多个主机;ARP(地址解析协议)和RARP(逆向地址解析协议)是某些接口(如以太网)使用的特殊协议,用来转换IP层和数据链路层使用的地址。

二、以太网数据的分用

图二 以太网数据的分用过程

       当目的主机收到一个以太网数据帧时,数据就开始从协议栈中由底向上升,同时去掉各层协议加上的报文首部。每层协议盒都要去检查报文首部中的协议标识,以确定接收数据上层协议。

三、故障现象

       用户抱怨打开网页速度慢,引起这个的原因有很多,比如通道拥塞,端口错误率高,局域网中有广播风暴等;

四、排错过程

        先用ping工具来排查,ping两端的网关,不丢包,ping大包也不丢包,接着再ping服务器和客户端PC,也不丢包,从客户端ping服务器同样不丢包,检查往返路由,径路一致,初步分析可以排除网络层和数据链路层的原因。

       从tcp/ip协议模型来看,往上就到了传输层,远程登录到客户端PC,刷新一个网页大概要等20S左右,用户体验确实非常差。网页采用的是http协议,看来只有用wireshark抓包分析了。http协议使用的传输层协议是tcp,我们知道任何的tcp协议在传输数据之前都要进行TCP三次握手,下图是用wireshark抓到的原始数据,我们对刷新页面这个动作的tcp流进行跟踪。

图三 打开网页的TCP连接

从上图可以看出,第一行表示请求端发送了一个SYN包,指明了客户打算连接的服务器端口以及本端所能接收的MSS(最大报文段长度)值,第二行表示服务器回包进行应答和确认,第三表示客户端对服务器的回包进行确认,这个过程就是三次握手(three-way handshake)的过程,第8行,10行、12行表示了tcp重传。

从原始的数据包来看,三次握手后,出现了tcp重传,三次握手到重传成功的时间间隔大概是20S左右,和我们刷新网页等待的时间一致,只要找到tcp重传的原因,应该就可以解决这个问题。

图四 RTO时间是21.122秒
图5 TCP报文的长度536

Mss(最大报文长度)表示TCP传往另一端的最大块数据的长度。当一个连接建立时,每一方都有用于通告它期望接受的MSS选项(MSS选项只能出现在SYN报文段中)。如果一方不接收来自另一方的MSS值,则mss就定为默认值536字节。

观察这个tcp流,tcp重传的数据被分段了,每个段590byte,数据长536byte,数据+tcp头+ip头+二层头=536+20+20+14=590,而这个536恰好是MSS的默认值,前面已经说过mss值只在三次握手的sync包着带着,这意味着通信双方的mss值没有协商成功,mss自动降为默认值536byte,这是导致数据出现分段重传的原因。

五、解决办法

       如果把客户端的mss值改成和服务器端的mss一样,会否就不重传了呢?马上登录网关,在接口上启用 tcp adjust-mss 1024 这条命令,验证网页打开的速度,0.1S的延时,再次抓包,tcp的mss值变为1024,虽然出现了tcp分段,但不再重传。

图六 网页访问正常

为何TCP进行536的分段后会重传,而且重传了20多秒,难道和应用有关?

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容

  • 1.这篇文章不是本人原创的,只是个人为了对这部分知识做一个整理和系统的输出而编辑成的,在此郑重地向本文所引用文章的...
    SOMCENT阅读 13,053评论 6 174
  • 个人认为,Goodboy1881先生的TCP /IP 协议详解学习博客系列博客是一部非常精彩的学习笔记,这虽然只是...
    贰零壹柒_fc10阅读 5,051评论 0 8
  • 简介 用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者...
    保川阅读 5,950评论 1 13
  • 18.1 引言 TCP是一个面向连接的协议。无论哪一方向另一方发送数据之前,都必须先在双方之间建立一条连接。本章将...
    张芳涛阅读 3,356评论 0 13
  • 1.OSI七层 TCP/IP五层 1.1 OSI七层参考模型 对于OSI七层参考模型,我想说只有这七个词条.任何与...
    破弓阅读 1,227评论 3 0