【项目 计网6】 4.17 TCP三次握手 4.18滑动窗口 4.19TCP四次挥手

这篇具有很好参考价值的文章主要介绍了【项目 计网6】 4.17 TCP三次握手 4.18滑动窗口 4.19TCP四次挥手。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


4.17 TCP三次握手

TCP 是一种面向连接的单播协议,在发送数据前,通信双方必须在彼此间建立一条连接。所谓的“连接”,其实是客户端和服务器的内存里保存的一份关于对方的信息,如 IP 地址、端口号等。

TCP 可以看成是一种字节流,它会处理 IP 层或以下的层的丢包、重复以及错误问题。在连接的建立过程中,双方需要交换一些连接的参数。这些参数可以放在 TCP 头部。

TCP 提供了一种可靠、面向连接、字节流、传输层的服务,采用三次握手建立一个连接。采用四次挥手来关闭一个连接。
【项目 计网6】 4.17 TCP三次握手 4.18滑动窗口 4.19TCP四次挥手,tcp/ip,网络,网络协议

  • 16 位端口号(port number):告知主机报文段是来自哪里(源端口)以及传给哪个上层协议或应用程序(目的端口)的。进行 TCP 通信时,客户端通常使用系统自动选择的临时端口号。
  • 32 位序号(sequence number):一次 TCP 通信(从 TCP 连接建立到断开)过程中某一个传输方向上的字节流的每个字节的编号。假设主机 A 和主机 B 进行 TCP 通信,A 发送给 B 的第一个TCP 报文段中,序号值被系统初始化为某个随机值 ISN(Initial Sequence Number,初始序号值)。那么在该传输方向上(从 A 到 B),后续的 TCP 报文段中序号值将被系统设置成 ISN 加上该报文段所携带数据的第一个字节在整个字节流中的偏移。例如,某个 TCP 报文段传送的数据是字节流中的第 1025 ~ 2048 字节,那么该报文段的序号值就是 ISN + 1025。另外一个传输方向(从B 到 A)的 TCP 报文段的序号值也具有相同的含义。
  • 32 位确认号(acknowledgement number):用作对另一方发送来的 TCP 报文段的响应。其值是收到的 TCP 报文段的序号值 + 标志位长度(SYN,FIN) + 数据长度 。假设主机 A 和主机 B 进行TCP 通信,那么 A 发送出的 TCP 报文段不仅携带自己的序号,而且包含对 B 发送来的 TCP 报文段的确认号。反之,B 发送出的 TCP 报文段也同样携带自己的序号和对 A 发送来的报文段的确认序号。
  • 4 位头部长度(head length):标识该 TCP 头部有多少个 32 bit(4 字节)。因为 4 位最大能表示15,所以 TCP 头部最长是60 字节。
  • 6 位标志位包含如下几项:
    URG 标志,表示紧急指针(urgent pointer)是否有效。
    ACK 标志表示确认号是否有效。我们称携带 ACK 标志的 TCP 报文段为确认报文段。(Acknowledge character)
    PSH 标志,提示接收端应用程序应该立即从 TCP 接收缓冲区中读走数据,为接收后续数据腾出空间(如果应用程序不将接收到的数据读走,它们就会一直停留在 TCP 接收缓冲区中)。
    RST 标志,表示要求对方重新建立连接。我们称携带 RST 标志的 TCP 报文段为复位报文段。
    SYN 标志表示请求建立一个连接。我们称携带 SYN 标志的 TCP 报文段为同步报文段。(Synchronize Sequence Numbers)
    FIN 标志表示通知对方本端要关闭连接了。我们称携带 FIN 标志的 TCP 报文段为结束报文段。(Finished)
    16 位窗口大小(window size):是 TCP 流量控制的一个手段。这里说的窗口,指的是接收通告窗口(Receiver Window,RWND)。它告诉对方本端的 TCP 接收缓冲区还能容纳多少字节的数据,这样对方就可以控制发送数据的速度。
    16 位校验和(TCP checksum):由发送端填充,接收端对 TCP 报文段执行 CRC 算法以校验TCP 报文段在传输过程中是否损坏。注意,这个校验不仅包括 TCP 头部,也包括数据部分。这也是 TCP 可靠传输的一个重要保障。
    16 位紧急指针(urgent pointer):是一个正的偏移量。它和序号字段的值相加表示最后一个紧急数据的下一个字节的序号。因此,确切地说,这个字段是紧急指针相对当前序号的偏移,不妨称之为紧急偏移。TCP 的紧急指针是发送端向接收端发送紧急数据的方法。

时序图
【项目 计网6】 4.17 TCP三次握手 4.18滑动窗口 4.19TCP四次挥手,tcp/ip,网络,网络协议
三次握手的目的是保证双方互相之间建立了连接。
双方都要确认四个信息:自己的首发和对方的收发。
三次握手发生在客户端连接的时候,当调用connect(),底层会通过TCP协议进行三次握手。
第一次握手:
1、客户端将SYN标志位置为1
2、生成一个随机的32位的序号seq=J,这个序号后边是可以携带数据(数据的大小)
第二次握手:
1、服务端接收客户端的连接:ACK=1
2、服务端会发出一个确认序号ack=客户端的序号+数据长度+SYN/FIN(按一个字节算)
3、服务端会向客户端发起连接请求:SYN=1
4、服务端会生成一个随机序号:seq=K
第三次握手:
1、客户端应答服务器的连接请求:ACK=1
2、客户端回复收到了客户端的数据:ack=服务端的序号+数据长度+SYN/FIN(按一个字节算)

前两次握手是带不了数据的,最后一次握手其实是可以携带数据的。

【项目 计网6】 4.17 TCP三次握手 4.18滑动窗口 4.19TCP四次挥手,tcp/ip,网络,网络协议

seq:sequence 序号
sseq:server sequence
cseq:client sequence
ack:acknowledge 确认号
只有当接收到报文段里面的SYN或者FIN置1的时候,确认方Ack=发起方Req+1
在初始三次握手的时候cseq和sseq都是按照一定规律的随机数。

以第一次发送数据为例:
此时的cseq = 上一轮的sack 也就是1001,(100)表示这一次要发送100字节。
服务器收到以后,就返回一个sack = 上一个cseq+数据大小 = 1001+100 = 1101。
每一个数据包都会被分配一个序号,这样32位序号和32位确认号就保证了数据报的顺序和完整性。

4.18滑动窗口

滑动窗口(Sliding window)是一种流量控制技术。早期的网络通信中,通信双方不会考虑网络的拥挤情况直接发送数据。由于大家不知道网络拥塞状况,同时发送数据,导致中间节点阻塞掉包,谁也发不了数据,所以就有了滑动窗口机制来解决此问题。滑动窗口协议是用来改善吞吐量的一种技术,即容许发送方在接收任何应答之前传送附加的包。接收方告诉发送方在某一时刻能送多少包(称窗口尺寸)。
滑动窗口(滑动窗口)是一种流量控制技术.早期的网络通信中,通信双方不会考虑网络的拥挤情况直接发送数据.由于大家不知道网络拥塞状况,同时发送数据,导致中间节点阻塞掉包,谁也发不了数据,所以就有了滑动窗口机制来解决此问题.滑动窗口协议是用来改善吞吐量的一种技术,即容许发送方在接收任何应答之前传送附加的包.(接收方告诉发送方在某一时刻能送多少包(称窗口尺寸)。

TCP中采用滑动窗口来进行传输控制,滑动窗口的大小意味着接收方还有多大的缓冲区可以用于接收数据。发送方可以通过滑动窗口的大小来确定应该发送多少字节的数据。当滑动窗口为0时,发送方一般不能再发送数据报。
Tcp中采用滑动窗口来进行传输控制,滑动窗口的大小意味着接收方还有多大的缓冲区可以用于接收数据发送方可以通过滑动窗口的大小来确定应该发送多少字节的数据.当滑动窗口为0时,发送方一般不能再发送数据报.

滑动窗口是TCP中实现诸如ack确认、流量控制、拥塞控制的承载结构.

窗口理解为缓冲区的大小
滑动窗口的大小会随着发送数据和接收数据而变化。
通信双方都有发送缓冲区和接收数据的缓冲区
服务器:
发送缓冲区(发送缓冲区的窗口)
接收缓冲区(接收缓冲区的窗口)
客户端
发送缓冲区(发送缓冲区的窗口)
接收缓冲区(接收缓冲区的窗口)
【项目 计网6】 4.17 TCP三次握手 4.18滑动窗口 4.19TCP四次挥手,tcp/ip,网络,网络协议
上图中:
发送方的缓冲区:
白色格子:空闲的空间
灰色格子:数据已经被发送出去,但是还没有被接收
紫色格子:还没有发送出去的数据

接收方的缓冲区:
白色格子:空闲的空间
紫色格子:已经接收到的数据

【项目 计网6】 4.17 TCP三次握手 4.18滑动窗口 4.19TCP四次挥手,tcp/ip,网络,网络协议
MSS:Maxmiun segment size:一条数据的最大数据量
win:滑动窗口大小(window)
1、第一次握手,客户端向服务端发起连接,客户端的滑动窗口是4096,一次发送的最大数据量是1460
2、第二次握手,服务端接收连接情况,告诉客户端服务器窗口大小是6144,一次发送的最大数据量是024
3、第三次握手
4、4-9连续给服务器发送了6K的数据,每次发送1K
5、第10次,服务端告诉客户端:发送的6K数据已经收到,存储在缓冲区,缓冲区已经处理了2K,窗口大小是2K
6、第11次,服务端告诉客户端:发送的6K数据已经收到,存储在缓冲区,缓冲区已经处理了4K,窗口大小是4K
7、第12次,客户端给服务端发送了1K的数据
8、第一次挥手:第13次,客户端主动请求和服务端断开连接,并且给服务器发送了1K的数据
9、第二次挥手:第14次,服务端回复ACK:8194(7169+1024+1 这个1表示收到了客户端发来的FIN),同意断开连接的请求,告诉客户端已经接收到方才发送的2K数据,滑动窗口2K
10、第15、16次,通知客户端滑动窗口的大小
11、第17次:第三次挥手,服务端向客户端发送FIN,请求断开连接
12、第18从,第四次挥手,客户端同意了服务端的断开请求

4.19TCP四次挥手

四次挥手,在程序中,当调用close()会使用TCP协议进行四次挥手。
客户端和服务端都可以主动发起断开连接,谁先调用close()谁就发起。
因为在TCP连接的时候,采用三次握手建立的连接是双向的,在断开的时候需要双向断开。
【项目 计网6】 4.17 TCP三次握手 4.18滑动窗口 4.19TCP四次挥手,tcp/ip,网络,网络协议文章来源地址https://www.toymoban.com/news/detail-683133.html

到了这里,关于【项目 计网6】 4.17 TCP三次握手 4.18滑动窗口 4.19TCP四次挥手的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Linux网络编程二(TCP图解三次握手及四次挥手、TCP滑动窗口、MSS、TCP状态转换、多进程/多线程服务器实现)

    1、TCP三次握手 TCP 三次握手 (TCP three-way handshake)是 TCP协议建立可靠连接 的过程,确保客户端和服务器之间可以进行可靠的通信。下面是TCP三次握手的 详细过程 : 假设客户端为A,服务器为B。 (1) 第一次握手 第一次握手(SYN=1,seq=500) A向B发送一个带有 SYN 标志位的数据包,

    2024年04月22日
    浏览(55)
  • 4.18 TCP 和 UDP 可以使用同一个端口吗?

    目录 TCP 和 UDP 可以同时绑定相同的端口吗? 多个 TCP 服务进程可以绑定同一个端口吗? 重启 TCP 服务进程时,为什么会有“Address in use”的报错信息? 重启 TCP 服务进程时,如何避免“Address in use”的报错信息? 客户端的端口可以重复使用吗? 多个客户端可以 bind 同一个端口

    2024年02月11日
    浏览(54)
  • 网路原理-传输层UDP,TCP/IP(确认应答,超时重传,连接管理,三次握手,四次挥手,状态转换,流量控制,滑动窗口,拥塞控制,延时应答,捎带应答,异常情况,面向字节流)-网络层(IP协议,地址管理)

    本节重点 • 理解传输层的作⽤,深⼊理解TCP的各项特性和机制 • 对整个TCP/IP协议有系统的理解 • 对TCP/IP协议体系下的其他重要协议和技术有⼀定的了解 我们之前编写完了基本的 java socket ,要知道,我们之前所写的所有代码都在应⽤层,都是为了 完成某项业务,如翻译等。

    2024年04月15日
    浏览(58)
  • 【网络|TCP】三次握手、四次握手

    TCP是一种面向连接的可靠的传输协议,建立和断开TCP连接时需要进行握手的过程。其中,TCP的连接建立需要进行三次握手,而连接断开则需要进行四次握手。 三次握手 第一次握手:客户端发送一个SYN(同步)报文给服务器,表示客户端请求建立连接。这个报文中包含一个初

    2024年02月14日
    浏览(39)
  • TCP | TCP协议格式 | 三次握手

    1.TCP协议 为什么需要 TCP 协议 ?TCP 工作在哪一层? IP网络层是不可靠的,TCP工作在传输层,保证数据传输的可靠性。 TCP全称为 “传输控制协议(Transmission Control Protocol”)。 TCP 是 面向连接的、可靠的、基于字节流 : 面向连接 :一定是「一对一」才能连接,不能像 UDP 协议

    2024年03月24日
    浏览(39)
  • TCP的三次握手

             TCP 是一种面向连接的单播协议,在发送数据前,通信双方必须在彼此间建立一条连接。所谓的“连接”,其实是客户端和服务器的内存里保存的一份关于对方的信息,如 IP 地址、端口号等。         TCP 可以看成是一种字节流, 它会处理 IP 层或以下的层的丢

    2024年02月03日
    浏览(43)
  • TCP三次握手详解

    TCP 传输控制协议  面向连接的可靠传输协议--在完成了传输层的基础工作外,还需要保障传输的可靠性; 面向连接:在传输数据前,需要通过三次握手建立端到端的虚链路 可靠传输:传输过程中使用到4种可靠传输机制;-- 确认、排序、流控(滑动窗口)、重传 TCP建连接三次

    2024年02月15日
    浏览(32)
  • TCP三次握手

    三次握手指的是TCP协议建立连接的过程。当客户端请求与服务器建立TCP连接时,必须要经过三次握手才能真正建立连接。 【动图演示 TCP3 次握手过程 连接状态变化 为什么是3次握手而不是2次】 https://www.bilibili.com/video/BV13V411w7Xq/?share_source=copy_webvd_source=1aab39b433529f6f488e61847b342

    2024年02月07日
    浏览(41)
  • TCP的三次握手过程

    TCP 是面向连接的协议,所以使用 TCP 前必须先建立连接,而 建立连接是通过三次握手来进行的 。三次握手的过程如下图: 刚开始客户端处于 closed 的状态,服务端处于 listen 状态 。 第一次握手:客户端给服务端发一个 SYN 报文,客户端会随机初始化序号( client_isn )。此时

    2024年02月16日
    浏览(46)
  • 详解TCP的三次握手

    定义 TCP是一种面向连接(连接导向)的、可靠的基于字节流的传输层通信协议。TCP将用户数据打包成报文段,发送后会启动一个定时器,然后另一端收到的数据进行确认、对失序的数据重新排序、丢弃重复数据 特点 TCP是面向连接的传输控制层协议 每一条TCP连接只能有两个端

    2024年02月05日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包