<返回更多

说起来 TCP 的连接与释放真是个浪漫的故事呢!

2020-06-11    
加入收藏
说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

作者 | JunSIr_deCp

责编 | 王晓曼

来源 | CSDN博客

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

TCP/IP协议概述

在TCP/IP协议栈,传输层有两个协议TCP和UDP:

以上定义,下面来详讲:

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

传输层协议的作用体现在应用层协议

TCP和UDP协议内指定不同的端口即可对应一个应用层的协议。

端口代表主机服务的侦听"门牌号",不管是TCP还是UDP,带上门牌号,它就能帮你找到主机上的对应服务。

例如我们在浏览器访问某个网站地址,这个动作会被我们本机上的80端口侦听到,并处理你的网络请求。

我们主机上常见的应用层协议端口:

但是我们通过TCP/UDP封装的数据包,通过本机侦听服务发送到目标主机,目标主机是如何识别并处理的呢?

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

如上图,我们会在数据包中添加目标端口号,这样目标主机相关服务侦听到,就能处理我们的请求了。

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

TCP/UDP传输层协议与网络层协议的区别

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

说白了,IP协议主要让数据能知道传到哪去,不管对应目标谁来负责接待,而TCP/UDP管。

越靠近顶层应用层、功能越强大。

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

UDP协议

主要特点:

基本描述:

UDP首部:

首先得知道数据包在OSI模型中层层传输,自顶向下。

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

来看看UDP首部:

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划 说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

TCP协议

基本特点:

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

上图可以看出TCP传输是如何面向字节流的,具体细节后面继续解析:

TCP连接基于Socket:

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

TCP协议确保可靠传输

TCP使用自动重传请求ARQ (Automatic Repeat reQuest)确保可靠传输;

停止等待机制:

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

报文过不了检验的,被B丢弃,A发送发出去的报文无回应、重新发送。

请注意:

确认丢失和确认迟到机制:

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

使用上述的确认和重传机制,我们就可以在不可靠的传输网络上实现可靠的通信。

ARQ 表明重传的请求是自动进行的。

TCP流水线传输:停止等待协议的优点是简单,但缺点是信道利用率太低。

改进:

发送方可连续发送多个分组,不必每发完一个分组就停顿下来等待对方的确认,由于信道上一直有数据不间断地传送,这种传输方式可获得很高的信道利用率。

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

连续 ARQ 协议(自动重传协议):连续ARQ(AutomaticRepeat reQuest)协议指发送方维持着一个一定大小的发送窗口,位于发送窗口内的所有分组都可连续发送出去,而中途不需要等待对方的确认。这样信道的利用率就提高了。而发送方每收到一个确认就把发送窗口向前滑动一个分组的位置;

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

接收方一般都是采用积累确认的方式。这就是说,接收方不必对收到的分组逐个发送确认,而是在收到几个分组后,对按序到达的最后一个分组发送确认,这就表示:到这个分组为止的所有分组都已正确收到了;

积累确认有优点也有缺点。优点是:容易实现,即使确认丢失也不必重传。但缺点是不能向发送方反映出接收方已经正确收到的所有分组的信息;

例如,如果发送方发送了前5个分组,而中间的第3个分组丢失了。这时接收方只是对前两个分组发出确认。发送方无法知道后面三个分组的下落,而只好把后面的三个分组都再重传一次。这就叫做Go-back-N(回退N),表示需要再退回来重传已发送过的N个分组。可见当通信线路质量不好时,连续ARQ协议会带来负面的影响。

TCP 报文段的首部格式:

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划 说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

滑动窗口

1、TCP 可靠通信的具体实现:

2、窗口动态变化-以字节为单位的滑动窗口:

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

相关名词:

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划 说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

TCP流量控制

流量控制(flowcontrol)就是让发送方的发送速率不要太快,既要让接收方来得及接收,也不要使网络发生拥塞。

利用滑动窗口机制可以很方便地在 TCP 连接上实现流量控制,收方返回的 rwnd中会包含自己的接收窗口的大小,并且利用大小来控制发送方的数据发送,发送方在rwnd窗口之后的数据不允许发送。

流量控制根本目的是防止分组丢失,它是构成TCP可靠性的一方面。

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

死锁解决:

接收方返回窗口大小为0,可能是缓冲区已满,需要处理缓存中的字节,发送端收到滑动窗口为0,不再发送,但是数据还没发送完,这就造成了死锁;

如果在某个时候,接收方缓冲区有空间了,于是发送了一个非 0 窗口的通告给接收方,不幸的是这个通告丢失了,而发送方却还在死等接收方的非 0 窗口通告,接下来就成了死锁;

TCP 为每一个连接设有一个持续计时器:

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

三次握手齐白首

传输连接有三个阶段,即:连接建立(三次握手)、数据传送和连接释放(四次挥手)。

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

头两次握手除了确定双方都能联通外,还通知了双方的一些端口信息:

A:我们谈恋爱吧;

B:好的(如果“好的“丢了,A就不知道B的态度,感情就无法建立起来);

C:走你~

第三次握手原因:假如把三次握手改成仅需要两次握手,死锁是可能发生的。作为例子,考虑计算机A和B之间的通信,假定A给B发送一个连接请求分组,B收到了这个分组,并发送了确认应答分组。

按照两次握手的协定,B认为连接已经成功地建立了,可以开始发送数据分组。可是,B的应答分组在传输中被丢失的情况下,A将不知道B是否已准备好,A认为连接还未建立成功,将忽略B发来的任何数据分组,这样就形成了死锁。

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

四次挥手说分手

说起来 TCP 的连接与释放真是个浪漫的故事呢!| 原力计划

A 的应用进程先向其 TCP 发出连接释放报文段,并停止再发送数据,主动关闭 TCP

连接:

版权声明:本文为CSDN博主「JunSIr_deCp」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:
https://blog.csdn.net/junsirhl/article/details/106155015

声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多资讯 >>>