TCP三次握手和Time-Wait状态
- 第一次握手:建立连接时。client发送
syn
包和一个随机序列号seq=x
到server,并进入SYN_SEND
状态,等待server进行确认。(
syn
,同 步序列编号)。 - 第二次握手,server收到
syn
包,必须确认客户的SYN
。然后server发送一个ACK=1, SYN=1, seq=y
的随机数和ack=x+1
的确认数的包发送回去。 - 第三次握手是client收到server端的
SYN+ACK
包,然后向server端发送确认包ack=y+1, seq=x+1, ACK=1
,client和server端进入ESTABLISHED
状态,完毕三次握手。详细图演示样例如以下(ACK
表示首部中的ACK
位置1。ack
表示首部中确认序号字段的值):
这里多说一点,既然提到了连接时的三次握手,就顺便把断开连接时的四次挥手也复习一下。
- 首先client主动发送
Fin=1,seq=u
。它等于前面已传 送过去的最后一个字节的序号加1.这时A
进入FIN-WAIT-1
状态。等待B
的确认。 B
收到连接后马上发出确认。确认号是ack=u+1
,而这个报文段 自己的序号是v
。等于B
前面已传送过的数据的最后一个字节的序号加1.然后B
即进入CLOSE-WAIT
状态。因而A
到B
的这个链接如今已经断开了,这时 的TCP
连接处于半关闭状态。即A
已经没有数据须要发送了。但
B
若发送数据,A
还是要接受的。A
收到来自B
的确认之后就进入了FIN-WAIT-2
状态等 待B
发出连接释放报文段。- 若
B
已经没有要向A
发送数据。其应用进程就通知TCP
释放连接。这时B
发出的连接释放报文段必须使用FIN=1
.如今假定B
的序 号为w
,B
还必须反复上次已发送过的确认号ack=u+1
.这时B
就进入了LAST-ACK
状态。等待A
确认。 A
在收到B
的连接释放之后必须对此发出确 认。在确认号中把ACK
置1。确认号ack=w+1
,而自己的序号是seq=u+1
。接着A
进入TIME-WAIT
状态。为了保证B
能够收到确认释放报文段。例如以下图:
是不是全部运行主动关闭的socket
都会进入TIME_WAIT
状态呢?
有没有什么情况使主动关闭的socket
直接进入CLOSED
状态呢?
主动关闭的一方在发送最后一个 ack
后
就会进入 TIME_WAIT
状态 停留2MSL
(max segment lifetime
)时间
这个是TCP/IP
不可缺少的,也就是“解决”不了的。也就是TCP/IP
设计者本来是这么设计的
主要有两个原因:
- 防止上一次连接中的包,迷路后又一次出现,影响新连接
(经过2MSL
,上一次连接中全部的反复包都会消失) - 可靠的关闭
TCP
连接
在主动关闭方发送的最后一个ack(fin)
,有可能丢失。这时被动方会又一次发
fin
, 假设这时主动方处于CLOSED
状态 ,就会响应rst
而不是ack
。所以
主动方要处于TIME_WAIT
状态,而不能是CLOSED
。
$(function () {
$('pre.prettyprint code').each(function () {
var lines = $(this).text().split('\n').length;
var $numbering = $('
- ').addClass('pre-numbering').hide();
$(this).addClass('has-numbering').parent().append($numbering);
for (i = 1; i ').text(i));
};
$numbering.fadeIn(1700);
});
});
TCP三次握手和Time-Wait状态的更多相关文章
- TCP三次握手及TCP连接状态 TCP报文首部格式
建立TCP连接时的TCP三次握手和断开TCP连接时的4次挥手整体过程如下图: 开个玩笑 ACK: TCP协议规定,只有ACK=1时有效,连接建立后所有发送的报文ACK必须为1 SYN(SYNchron ...
- [转]Linux服务器上11种网络连接状态 和 TCP三次握手/四次挥手详解
一.Linux服务器上11种网络连接状态: 图:TCP的状态机 通常情况下:一个正常的TCP连接,都会有三个阶段:1.TCP三次握手;2.数据传送;3.TCP四次挥手. 注:以下说明最好能结合”图:T ...
- TCP三次握手,四次挥手,状态变迁图
body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...
- 使用 tcpdump 抓包分析 TCP 三次握手、四次挥手与 TCP 状态转移
目录 文章目录 目录 前文列表 TCP 协议 图示三次握手与四次挥手 抓包结果 抓包分析 TCP 三次握手 数据传输 四次挥手 TCP 端口状态转移 状态转移 前文列表 <常用 tcpdump ...
- wireshark抓包工具简介以及tcp三次握手的一些含义
wireshark是非常流行的网络封包分析软件,功能十分强大.可以截取各种网络封包,显示网络封包的详细信息.使用wireshark的人必须了解网络协议,否则就看不懂wireshark了.为了安全考虑, ...
- TCP三次握手四次挥手
看到一篇总结很好的TCP三次握手,学习一下,原文链接. 建立TCP需要三次握手才能建立,而断开连接则需要四次握手.整个过程如下图所示: 先来看看如何建立连接的. 首先Client端发送连接请求报文,S ...
- TCP ,UDP概念和TCP三次握手连接 的知识点总结
OSI 计算机网络7层模型 TCP/IP四层网络模型 传输层提供应用间的逻辑通信(端到端),网络层提供的是主机到主机的通信,传输层提供的是可靠服务. TCP 中常说的握手指的是:连接的定义和连接的建立 ...
- TCP 三次握手四次挥手, ack 报文的大小.tcp和udp的不同之处、tcp如何保证可靠的、tcp滑动窗口解释
一.TCP三次握手和四次挥手,ACK报文的大小 首先连接需要三次握手,释放连接需要四次挥手 然后看一下连接的具体请求: [注意]中断连接端可以是Client端,也可以是Server端. [注意] 在T ...
- iOS 开发:TCP三次握手连接
在TCP/IP协议中,TCP协议提供可靠的连接服务,采用三次握手建立一个连接. 第一次握手:建立连接时,客户端发送syn包(syn=j)到服务器,并进入SYN_SEND状态,等待服务器确认: 第二次握 ...
- TCP三次握手原理详解
TCP/IP协议不是TCP和IP这两个协议的合称,而是指因特网整个TCP/IP协议族. 从协议分层模型方面来讲,TCP/IP由四个层次组成:网络接口层.网络层.传输层.应用层. TCP协议:即传输控制 ...
随机推荐
- VMware Workstation 9.0 安装苹果Mac OS X10.9系统
摘自:http://www.wuwenhui.cn/3133.html 一.安装所需要的软件: 1.VMware Workstation 9.0 点击下载 2.unlock-all-v110.zip ...
- SQL 教程
SQL 教程 http://www.w3school.com.cn/sql/
- lua语法 - 基础篇
1. 注释 单行注释:--,类似于C++的// 多行注释:--[[ ... ]],类似于C++的/*...*/ 2. 语句 分隔符:分号或者空格,一般多行写一起,建议用分号 语句块:do ... en ...
- 托管到GitHub
如何把项目托管到GitHub iOS开发拓展篇——如何把项目托管到GitHub 说明:本文主要介绍如何把一个OC项目托管到Github,重操作轻理论. 第一步:先注册一个Github的账号,这是必须的 ...
- java class生成jar包(转)
进入dos操作符窗口cd进入要打成jar包的class文件所有文件夹目录jar cvf [生成jar的名称.jar] [列出class文件] //若有多个,以空隔隔开 如:一.操作零散的单个或几个cl ...
- Perl 面向对象编程的两种实现和比较:
<pre name="code" class="html">https://www.ibm.com/developerworks/cn/linux/ ...
- ASP.NET - 对URL传递的值进行编码Server.UrlEncode()
/// <summary> /// 搜索内容 /// </summary> /// <param name="sender"></para ...
- Eclipse用法和技巧十:显示代码outline
在一个文件中快速找到某一个方法或者某一个作用域,可以使用 Ctrl+O或者Ctrl+F3,快速显示当前代码的outline,进行快速查找.效果如下: 这里主要是补充一些后续操作,能更加方 ...
- Eclipse用法和技巧七:自动生成get和set方法2
上一篇文章中我们介绍了自动批量生成get和set函数的方法.这个方法一般在声明完类的数据域之后使用,比较方便快捷.这里再补充几个自动生成get和set函数的方法. 步骤一:在声明的数据域中按Ctrl+ ...
- 基于visual Studio2013解决C语言竞赛题之1085相邻之和素数
题目 解决代码及点评 /************************************************************************/ /* ...