《TCP/IP详解卷1:协议》第19章 TCP的交互数据流-读书笔记

时间:2023-02-22 17:14:16

章节回顾:

《TCP/IP详解卷1:协议》第1章 概述-读书笔记

《TCP/IP详解卷1:协议》第2章 链路层-读书笔记

《TCP/IP详解卷1:协议》第3章 IP:网际协议(1)-读书笔记

《TCP/IP详解卷1:协议》第3章 IP:网际协议(2)-读书笔记

《TCP/IP详解卷1:协议》第4章 ARP:地址解析协议-读书笔记

《TCP/IP详解卷1:协议》第5章 RARP:逆地址解析协议-读书笔记

《TCP/IP详解卷1:协议》第6章 ICMP:Internet控制报文协议-读书笔记

《TCP/IP详解卷1:协议》第11章 UDP:用户数据报协议-读书笔记

《TCP/IP详解卷1:协议》第17、18章 TCP:传输控制协议(1)-读书笔记

《TCP/IP详解卷1:协议》第17、18章 TCP:传输控制协议(2)-读书笔记

《TCP/IP详解卷1:协议》第19章 TCP的交互数据流-读书笔记


1、引言

有关TCP通信量的研究发现:按分组数量计算,约有一半的TCP报文段包含成块数据(如FTP、电子邮件和Usenet新闻),另一半则包含交互数据(如Telnet和Rlogin)。按字节计算,成块数据与交互数据的比例约为90%和10%。

成块数据的报文段基本上都是满长度的(通常为512字节的用户数据),交互数据则小得多(Telnet和Rlogin分组中约90%左右的用户数据小于10个字节)

TCP需要同时处理这两类数据,但使用的处理算法不同。


2、交互式输入

说明:本书是以远程登录Rlogin协议模拟交互输入的,我没有进行相关实验,下面我会给出作者所做的实验截图。

如图19-1所示,Rlogin协议需要远程系统回显客户输入的字符,每按一个字符就会产生一个分组,而不是每次一行作为一个分组。

一般可以将报文段2和3合并(图中两个红框)

《TCP/IP详解卷1:协议》第19章 TCP的交互数据流-读书笔记

当我们键入5个字符date\n时的数据流,如图19-2所示:

《TCP/IP详解卷1:协议》第19章 TCP的交互数据流-读书笔记

说明:

(1)第1行:客户发送字符d到服务器;第2行:该字符的确认及回显;第3行:回显字符的确认。

(2)与字符a有关的是第4~6行,与字符t有关的是第7~9行,与字符e有关的是第10~12行。

(3)13~15行与上面稍有不同。客户发送到服务器的是一个字符(换行符),而回显的是两个字符(图中14行红线处),这两个字符为:回车和换行字符,作用是将光标移动到左边并换到下一行。

(4)第16行:来自服务器date命令的输出。这30个字节(图中红线处)由28个字符与最后的回车+换行组成。第17、18行:服务器发往客户7个字符(第18行),它们是在服务器主机上的客户提示符:svr4%。第19行:确认了这7个字符。


3、经受时延的确认

图19-3表示了图19-2中数据交换的时间。

《TCP/IP详解卷1:协议》第19章 TCP的交互数据流-读书笔记

通常TCP在接收到数据时并不立即发送ACK;它会推迟发送,以便将ACK与需要沿该方向发送的数据一起发送,有时称这种现象为数据捎带ACK

说明:绝大多数实现采用的时延为200ms,即TCP将以最大200ms的时延等待是否有数据一起发送。

下面我假设你会看这张图中标记的时间差,会计算实际时间(累加)。说明如下

观察bsdi接收到数据和发送ACK之间的时间差:123.5、65.6、109.0、132.2、42.0、140.3和195.8 ms,似乎是随机的。观察bsdi发送ACK的实际时间(从0开始计算)为:139.9、539.3、940.1、1339.9、1739.9、1940.1和2140.1 ms,这些时间差是200ms的整数倍。

注意:因为TCP使用了一个200ms的定时器,以相对于内核引导的200ms固定时间溢出。由于将要确认的数据是随机到达的,TCP在内核的200ms定时器的下一次溢出时得到通知。


4、Nagle算法

Rlogin连接时,一般每次发送一个字节到服务器,这就产生了一些41字节长的分组:20字节的IP首部、20字节的TCP首部和1个字节的数据。

在局域网上,这些小分组(被称为微小分组tinygram)通常不会引起麻烦,因为局域网一般不会出现拥塞。在广域网上,这些小分组则会增加拥塞出现的可能。一种简单有效的方法就是采用RFC 896建议的Nagle算法。

算法说明:

算法要求一个TCP连接上最多只能有一个未被确认的未完成的小分组,在该分组的确认到达之前不能发送其他的小分组。相反,TCP收集这些少量的分组,并在确认到来时以一个分组的方式发出去。

算法优点:

算法的优越之处在于它是自适应的:确认到达得越快,数据也就发送得越快。在希望减少微小分组数目的低速广域网上,则会发送更少的分组。

从图19-3中看到,在以太网上一个字节被发送、确认和回显的平均往返时间约为16ms。为了产生比这个速度更快的数据,我们每秒键入的字符必须多于60个。说明在局域网环境下两个主机之间发送数据时很少使用这个算法。

当往返时间(RTT)增加时,如通过一个广域网,情况发生了变化。如图19-4:

《TCP/IP详解卷1:协议》第19章 TCP的交互数据流-读书笔记

从左到右待发数据的长度是不同的,分别为:1、1、2、1、2、2、3、1和3个字节。这是因为客户只有收到前一个数据的确认后才发送已经收集的数据。通过使用Nagle算法,为发送16个字节的数据客户只需要使用9个报文段,而不再是16个

关闭Nagle算法

有时我们也需要关闭Nagle算法。例如,X窗口系统服务器,小消息(鼠标移动)必须无时延地发送,以便为进行某种操作的交互用户提供实时的反馈。


5、窗口大小通告

观察图19-4,可以看到slip通告窗口大小为4096字节,vangogh通告其窗口大小为8192字节。但报文段5通告的窗口大小为4095个字节,意味着TCP缓冲区中仍然有一个字节等待应用程序(Rlogin客户)读取。

说明:

(1)通常服务器通告窗口大小为8192个字节,这是因为服务器在读取并回显接收到的数据之前,其TCP没有数据发送。当服务器已经读取了来自客户的输入后,来自服务器的数据将被发送。

(2)在ACK到来时,客户的TCP总是有数据需要发送。这是因为它在等待ACK的过程中缓存接收到的字符。当客户TCP发送缓存的数据时,Rlogin客户没有机会读取来自服务器的数据,因此,客户通告的窗口大小总是小于4096。


小结:

交互数据总是以小于最大报文段长度的分组发送。对于这些小的报文段,接收方使用经受时延的确认方法来判断确认是否可被推迟发送,以便与回送数据一起发送。这样通常会减少报文段的数目。在较慢的广域网环境中,通常使用Nagle算法来减少这些小报文段的数目。这个算法限制发送者任何时候只能有一个发送的小报文段未被确认。

《TCP/IP详解卷1:协议》第19章 TCP的交互数据流-读书笔记的更多相关文章

  1. TCP/IP详解 卷1 第十九章 TCP的交互数据流

    19.1 引言 成块数据:比如ftp.电子邮件.Usenet新闻 交互数据:Telnet.Rlogin 成块数据的报文段基本上都是满长度(full-size)的,而交互数据小的多(Telnet和Rlo ...

  2. 【TCP/IP详解 卷一:协议】第二章:链路层

    2.1 引言 链路层的三个目的: (1)为IP模块发送和接收IP数据报. (2)为ARP模块发送ARP请求和接收ARP应答.地址解析协议:ARP. (3)为RARP模块发送RARP请求和接收RARP应 ...

  3. 【TCP/IP详解 卷一:协议】第一章概论 学习笔记

    第一章 概述 游览了一下,本章主要是简介OSI模型的低层(1-4层).介绍了TCP/IP协议族的相关知识. TCP/IP的分层 Application <--> TCP / UDP &lt ...

  4. tcp&sol;ip详解 卷1 -- 协议概述

    第一章 概述 分层 TCP/IP 通常被认为是一个四层协议系统. 每一层负责不同的功能. 链路层, 也成为数据链路层或者网络接口层. 通常包括 操作系统中的设备驱动程序和计算机中对应的网络接口卡. 主 ...

  5. 《TCP&sol;IP详解 卷1&colon;协议》读书笔记

    第一章 概述 协议栈 应用层 HTTP,FTP   运输层 TCP, UDP 段(Segment) 网络层 IP, ICMP, IGMP 数据报(Datagram) 链路层   帧(Frame) 物理 ...

  6. 【TCP&sol;IP详解 卷一:协议】第二十章 TCP的成块数据流

    本章节主要内容: ACK的累积 滑动窗口协议(即 接收方TCP数据报缓存的大小) 流量控制(慢启动 -发送方TCP的 拥塞窗口(cwnd) 以及接受方的 通告窗口) 20.1 引言 在教材的之前章节中 ...

  7. TCP&sol;IP详解 卷一(第十九章 TCP的交互数据流)

    TCP需要同时处理两类数据:块数据.交互数据. 本章将以Rlogin应用为例观察交互数据的传输过程. 交互式输入 首先观察在一个Rlogin连接上键入一个交互命令时所产生的数据流(每键入一个交互按键都 ...

  8. TCP&sol;IP详解卷1 - wireshark抓包分析

    TCP/IP详解卷1 - 系列文 TCP/IP详解卷1 - 思维导图(1) TCP/IP详解卷1 - wireshark抓包分析 引言 在初学TCP/IP协议时,会觉得协议是一种很抽象的东西,通过wi ...

  9. 《TCP&sol;IP详解卷1:协议》第1章 概述-读书笔记

    章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...

  10. 《TCP&sol;IP详解卷1:协议》第2章 链路层-读书笔记

    章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...

随机推荐

  1. 进程状态转换、CPU调度算法

    进程的状态转换 进程在运行中不断地改变其运行状态.通常,一个运行进程必须具有以下三种基本状态. 进程状态 执行态run:进程正在使用CPU 等待态wait:进程正在等待I/O完成,不在使用也不能使用C ...

  2. net-snmp的安装

    安装环境是ubuntu 14. 方法1:apt-get install  net-snmp (非root用户需要sudo 提升权限) 方法2:自定义安装选择不同的版本去编译. 1:先去下载所需要的ta ...

  3. NodeJS学习笔记—2&period;AMD规范

    CommonJS加载模块是同步的,而AMD模块加在是非同步的,允许指定回调函数.由于Nodejs主要用于服务器编程,模块文件一般都存在于本地,所以加载很快,不需要考虑非同步加载,用CommonJS即可 ...

  4. jquery的queue方法

    queue: queue主要用于给元素上的函数队列(默认名为fx)添加函数(动画效果),这样dequeue就可以取出并执行函数队列中的第一个函数(即最先进入函数队列的函数),delay则可以延迟元素上 ...

  5. Hive和Jdbc示例

    重要:在使用 JDBC 开发 Hive 程序时, 必须首先开启 Hive 的远程服务接口.使用下面命令进行开启:hive -service hiveserver & 1). 测试数据 user ...

  6. 双网卡绑定(suse)

    网卡绑定技术有助于保证高可用性特性并提供其它优势以提高网络性能,Linux双网卡绑定实现就是使用两块网卡虚拟成为一块网卡,这个聚合起来的设备看起来是一个单独的以太网接口设备,就是两块网卡具有相同的IP ...

  7. MySQL索引方法

    MySQL目前主要有以下几种索引方法:B-Tree,Hash,R-Tree. 一.B-Tree B-Tree是最常见的索引类型,所有值(被索引的列)都是排过序的,每个叶节点到跟节点距离相等.所以B-T ...

  8. GCD 多线程 ---的记录 iOS

    先写一个GCD static UserInfoVoModel *userInfoShare = nil; +(instancetype)shareUserInfoVoModel { static di ...

  9. HTML5图片上传本地预览

    在开发 H5 应用的时候碰到一个问题,应用只需要一张小的缩略图,而用户用手机上传的确是一张大图,手机摄像机拍的图片好几 M,这可要浪费很多流量. 我们可以通过以下方式来解决. 获取图片 通过 File ...

  10. python&lowbar;选择结构

    >>> if 3>2:print('ok') ok>>> if True:print(3);print(5) >>> chTesst=['1 ...