TCP/IP 浅谈

TCP发送数据过程

  1. 发送消息:计算机(发送端a)收到要发送消息的通知后,CPU把数据拆分成多段,然后网卡再次拆分成更细的粒度,通过三次握手,并行发送到另一端(接收端b)。
  2. 接收消息:由于发送端a是并行发送消息,接收端b收到的tcp段可能是乱序的,接收端b需要对接收到的tcp段进行排序,如果排序后发现收到的tcp段不完整(首尾缺失或者非连续性),则认为该次请求不完整,发送消息给发送端a,要求发送端a重新发送一遍(再走一遍三次握手)。

单攻和双工

假设有AB两个设备

单工

数据只能单向传递,要么A向B发送数据,要么B向A发送数据

半双工

数据传输方向没限制,但同一时间内数据流向唯一。也就是说,A端向B端发送数据时,B端不能同时向A端发送数据

两个选择二选一

全双工

同一时间,数据能双向传递。也就是说,A端向B端发送数据的同时,B端也能向A端发送数据

连接流程

三次握手

  1. 客户端向服务端发送连接请求(syn)
  2. 服务端响应
    1. 服务端准备好
    2. 服务端向客户端发送响应(ack)
    3. 服务端向客户端发送连接请求(syn)
  3. 客户端向服务端发送响应(ack)

传输数据规则

客户端为A,服务端为B。

  • 传输数据,S和A的序号约定+1。
  • 如果需要再往发送端(A)发送数据,接收方(B)把收到的数据(byte位)加到SYN序号并发送。
  • 每一次交换数据时,把从另一端收到的S和A的数值交换。

四次挥手

客户端为A,服务端为B

  1. 传输数据,S和A的序号约定+1。
  2. 发送端发出连接断开的请求
  3. 服务端连续发两次响应
  4. 客户端发送最后一次通讯后(ACK和SYN依然交换),序号实际值+1,连接断开。
相关推荐
企业对冲系统官31 分钟前
基差风险管理系统日志分析功能的架构与实现
大数据·网络·数据库·算法·github·动态规划
jarreyer1 小时前
TCP/IP五层模型
网络·网络协议·tcp/ip
我命由我123451 小时前
充血模型与贫血模型
java·服务器·后端·学习·架构·java-ee·系统架构
米高梅狮子2 小时前
02. 配置DNS服务器
运维·服务器·centos
Web3VentureView2 小时前
SYNBO 协议亮相 ChainThink “Meme 回归” AMA:市场奖励机制深度剖析
网络·金融·web3·区块链·加密货币
宴之敖者、2 小时前
Linux——指令
linux·运维·服务器
翔云1234563 小时前
(MySQLdb._exceptions.OperationalError) (2006, ‘MySQL server has gone away‘)
网络·python
Xの哲學3 小时前
Linux设备驱动模型深度解剖: 从设计哲学到实战演练
linux·服务器·网络·算法·边缘计算
半夏知半秋3 小时前
kcp学习-通用的kcp lua绑定
服务器·开发语言·笔记·后端·学习
Ydwlcloud3 小时前
AWS 2026折扣活动深度解析:寻找最大优惠的智慧路径
大数据·服务器·人工智能·云计算·aws