TCP 的三次握手
  

ztbf 1128

{{ttag.title}}
TCP 的三次握手A 为客户端,B 为服务器端。
  • 首先 B 处于 LISTEN(监听)状态,等待客户的连接请求。
  • A 向 B 发送连接请求报文,SYN=1,ACK=0,选择一个初始的序号 x。
  • B 收到连接请求报文,如果同意建立连接,则向 A 发送连接确认报文,SYN=1,ACK=1,确认号为 x+1,同时也选择一个初始的序号 y。
  • A 收到 B 的连接确认报文后,还要向 B 发出确认,确认号为 y+1,序号为 x+1。
  • B 收到 A 的确认后,连接建立。


  如图:
     


三次握手的原因第三次握手是为了防止失效的连接请求到达服务器,让服务器错误打开连接。如果有第三次握手,客户端会忽略服务器之后发送的对滞留连接请求的连接确认,不进行第三次握手,因此就不会再次打开连接。如果由于网络不稳定,虽然客户端以前发送的连接请求以到达服务方,但服务方的同意连接的应答未能到达客户端。则客户方要重新发送连接请求,若采用二次握手,服务方收到客服端重传的请求连接后,会以为是新的请求,就会发送同意连接报文,并新开进程提供服务,这样会造成服务方资源的无谓浪费。


打赏鼓励作者,期待更多好文!

打赏
1人已打赏

ie5000 发表于 2019-10-23 09:21
  
以前光知道三次握手是为了可靠,还没注意过还有其他原因
叶庆豪 发表于 2019-10-23 11:28
  
再次复习一下TCP三次握手
carl 发表于 2019-10-25 09:09
  
学习学习,这些知识点对平时做IT运维,排查错误还是很有用的!
tj_zero 发表于 2019-10-30 15:08
  
三次握手,是TCP传输协议重要的核心原理,并且为此称为面向连接可靠的;
Yxhong 发表于 2019-10-30 16:26
  
重温一下
朱墩2 发表于 2019-10-30 17:28
  
三次握手的原理对排查防火墙问题很有效果,当时防火墙做DNAT,端口能通,业务不通,后来抓包看,3次握手正常。但服务器发送了拒绝包,直接证明问题在服务器端
一个无趣的人 发表于 2019-10-30 19:32
  
三次握手是很常用的排错手段,握手成功,会话就有了 哈哈。
蟲爺 发表于 2022-3-3 12:47
  
感谢分享
发表新帖
热门标签
全部标签>
每日一问
功能体验
技术笔记
新版本体验
技术咨询
2023技术争霸赛专题
干货满满
技术盲盒
标准化排查
产品连连看
GIF动图学习
信服课堂视频
安装部署配置
秒懂零信任
自助服务平台操作指引
技术晨报
深信服技术支持平台
答题榜单公布
卧龙计划
畅聊IT
答题自测
云计算知识
通用技术
安全攻防
每日一记
sangfor周刊
资源访问
排障笔记本
专家问答
技术圆桌
在线直播
MVP
网络基础知识
升级
上网策略
测试报告
日志审计
问题分析处理
流量管理
运维工具
用户认证
原创分享
解决方案
VPN 对接
项目案例
SANGFOR资讯
专家分享
技术顾问
信服故事
SDP百科
功能咨询
终端接入
授权
设备维护
迁移
社区帮助指南
地址转换
虚拟机
存储
加速技术
产品预警公告
玩转零信任
信服圈儿
S豆商城资讯
技术争霸赛
「智能机器人」
追光者计划
纪元平台
华北区拉练
天逸直播
以战代练
山东区技术晨报
文档捉虫活动
齐鲁TV
华北区交付直播
每周精选

本版版主

12
185
6

发帖

粉丝

关注

本版达人

LoveTec...

本周分享达人

新手24116...

本周提问达人