TCP 的三次握手
  

ztbf 2434

{{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
  
感谢分享
发表新帖
热门标签
全部标签>
新版本体验
每日一问
纪元平台
社区新周刊
安全效果
产品连连看
功能体验
标准化排查
GIF动图学习
高手请过招
【 社区to talk】
信服课堂视频
安装部署配置
测试报告
SDP百科
终端接入
平台使用
每周精选
畅聊IT
答题自测
专家问答
技术笔记
技术圆桌
在线直播
MVP
网络基础知识
升级
安全攻防
上网策略
日志审计
问题分析处理
流量管理
每日一记
运维工具
用户认证
原创分享
解决方案
sangfor周刊
VPN 对接
项目案例
SANGFOR资讯
专家分享
技术顾问
信服故事
功能咨询
授权
设备维护
资源访问
地址转换
虚拟机
存储
迁移
排障笔记本
产品预警公告
玩转零信任
S豆商城资讯
技术争霸赛
「智能机器人」
追光者计划
2023技术争霸赛专题
卧龙计划
华北区拉练
天逸直播
以战代练
秒懂零信任
技术晨报
技术盲盒
山东区技术晨报
文档捉虫
齐鲁TV
华北区交付直播
2024年技术争霸赛
北京区每日一练
场景专题
故障笔记
排障那些事
西北区每日一问
升级&主动服务
高频问题集锦
POC测试案例
全能先锋系列
云化安全能力
专家说
热门活动
产品动态
行业实践
产品解析
关键解决方案

本版达人

feeling

本周分享达人

新手29676...

本周提问达人