三、TCP协议

简介: 三、TCP协议

TCP(Transmission Control Protocol)传输控制协议:顾名思义就是对数据的传输进行控制

TCP报头

00a54c0c3355d12d00f9f85f7c7815bd_4543.png

序号:相当于编号,当TCP数据包过大的时候会进行分段,分段之后按序号顺序重组,复原数据 seq=1

确认号:存在于第一次确认消息里的,希望服务器能够回应,确认号跟序号有联系 ack(确认号)=1+seq=2,表示我希望收到下一个包的序号为2

状态控制码:信号灯 1---亮 0---暗

  1. ACK -acknowledge(确认标志)=1那么代表这是一个确认消息,对方已确认
  2. RST -RESET(重置标志)=1 ,表示这个消息释放连接,TCP连接错误,请重新连接
  3. SYN -synchoronous(同步标志)=1,表示这个消息是:1.一个发起的连接 2.确认接受连接
  4. FIN -Final(中止标志)=1,表示发送报文完毕了,要释放连接,TCP四次挥手要开始了

客户端向百度服务器发起请求:首先是向TCP发起请求,实现的过程就是TCP三次握手

TCP四次挥手就是断开连接的过程

TCP三次握手

e596b241c1ced4ac6393bf6dd165dd0a_4558.png

 

be2ca6e4936ba7194c256b78c506f9da_4648.png

首先连接都是关闭的

  1. 第一次握手:Client将标志位SYN置为1,随机产生一个序号值seq=J,并将该数据包发送给Server,Client进入SYN_SENT状态,等待Server确认。
  2. 第二次握手:Server收到数据包后由标志位SYN=1知道Client请求建立连接,Server将标志位SYN和确认位ACK都置为1,并且确认号加1表示我希望收到的下一个包是ack=J+1,随机产生一个序号值seq=K,并将该数据包发送给Client以确认连接请求,Server进入SYN_RCVD状态。
  3. 第三次握手:Client收到确认后,检查ack是否为J+1,ACK是否为1,如果正确则将确认位ACK置为1,并且将之前的序号K加1,确认号ack=K+1,并将该数据包发送给Server,Server检查ack是否为K+1,ACK是否为1,如果正确则连接建立成功,Client和Server进入ESTABLISHED状态,完成三次握手,随后Client与Server之间可以开始传输数据了。

TCP四次挥手

332a81c27b5e68b3083a51ce5323f0c8_4659.png

 

49ee1a72e1fc20f71546dad654f15ea8_4665.png

  1. 第一次挥手:Client发送一个FIN,用来关闭Client到Server的数据传送,Client进入FIN_WAIT_1状态。
  2. 第二次挥手:Server收到FIN后,发送一个ACK给Client,确认序号为收到序号+1(与SYN相同,一个FIN占用一个序号),Server进入CLOSE_WAIT状态。
  3. 第三次挥手:Server发送一个FIN,用来关闭Server到Client的数据传送,Server进入LAST_ACK状态。
  4. 第四次挥手:Client收到FIN后,Client进入TIME_WAIT状态,接着发送一个ACK给Server,确认序号为收到序号+1,Server进入CLOSED状态,完成四次挥手。
相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
1月前
|
网络协议 算法 安全
|
4天前
|
缓存 网络协议 安全
TCP和UDP 传输层协议的区别
TCP协议全称是传输控制协议是一种面向连接的、可靠的、基于字节流的传输层通信协议。
9 2
|
8月前
|
网络协议 算法 网络性能优化
一文带你了解tcp协议
一文带你了解tcp协议
|
3月前
|
消息中间件 网络协议 网络性能优化
TCP和UDP协议详解
TCP和UDP协议详解
|
6月前
|
网络协议 算法 网络性能优化
关于TCP协议我们需要知道的
TCP协议是OSI模型中的传输层协议,用于建立和维护两个程序间的数据交换连接,以及通过Internet发送信息。TCP协议的主要特点包括面向连接、可靠性、流控制和拥塞控制。其中,三次握手和四次挥手是建立和断开TCP连接的必要过程。此外,TCP协议还提供了流控制机制来控制数据发送方的发送速度,以避免网络拥塞问题。
645 0
关于TCP协议我们需要知道的
|
7月前
|
缓存 网络协议
TCP协议与UDP协议
TCP协议与UDP协议
76 0
|
9月前
|
缓存 网络协议 网络性能优化
UDP 协议 vs TCP协议
UDP 协议 vs TCP协议
94 0
|
9月前
|
存储 网络协议 Unix
传输层——TCP协议(二)
传输层——TCP协议
52 0
|
9月前
|
网络协议 安全 算法
传输层——TCP协议(三)
传输层——TCP协议
54 0
|
10月前
|
缓存 网络协议 算法
有关TCP协议,这是我看过讲的最清楚的一篇文章了!
TCP 协议是网络传输中至关重要的一个协议,它位于传输层。向上支持 FTP、TELNET、SMTP、DNS、HTTP等常见的应用层协议,向下要与网络层的 IP 协议相互配合,实现可靠的网络传输。

热门文章

最新文章