关于TCP的状态机
来源:互联网 发布:毕业分布图制作软件 编辑:程序博客网 时间:2024/05/16 10:06
http://www.2cto.com/net/201111/112030.html
另外:
客户端与服务器端建立TCP/IP连接后关闭SOCKET后,服务器端连接的端口
状态为TIME_WAIT
状态为TIME_WAIT
是不是所有执行主动关闭的socket都会进入TIME_WAIT状态呢?
有没有什么情况使主动关闭的socket直接进入CLOSED状态呢?
有没有什么情况使主动关闭的socket直接进入CLOSED状态呢?
主动关闭的一方在发送最后一个 ack 后
就会进入 TIME_WAIT 状态 停留2MSL(max segment lifetime)时间
这个是TCP/IP必不可少的,也就是“解决”不了的。
也就是TCP/IP设计者本来是这么设计的
主要有两个原因
1。防止上一次连接中的包,迷路后重新出现,影响新连接
(经过2MSL,上一次连接中所有的重复包都会消失)
2。可靠的关闭TCP连接
在主动关闭方发送的最后一个 ack(fin) ,有可能丢失,这时被动方会重新发
fin, 如果这时主动方处于 CLOSED 状态 ,就会响应 rst 而不是 ack。所以
主动方要处于 TIME_WAIT 状态,而不能是 CLOSED 。
TIME_WAIT 并不会占用很大资源的,除非受到攻击。
还有,如果一方 send 或 recv 超时,就会直接进入 CLOSED 状态
就会进入 TIME_WAIT 状态 停留2MSL(max segment lifetime)时间
这个是TCP/IP必不可少的,也就是“解决”不了的。
也就是TCP/IP设计者本来是这么设计的
主要有两个原因
1。防止上一次连接中的包,迷路后重新出现,影响新连接
(经过2MSL,上一次连接中所有的重复包都会消失)
2。可靠的关闭TCP连接
在主动关闭方发送的最后一个 ack(fin) ,有可能丢失,这时被动方会重新发
fin, 如果这时主动方处于 CLOSED 状态 ,就会响应 rst 而不是 ack。所以
主动方要处于 TIME_WAIT 状态,而不能是 CLOSED 。
TIME_WAIT 并不会占用很大资源的,除非受到攻击。
还有,如果一方 send 或 recv 超时,就会直接进入 CLOSED 状态
- 关于TCP的状态机
- ip_conntrack的TCP状态机
- TCP的状态机
- TCP 状态机 理解TCP重要的环节
- TCP 状态机
- TCP 状态机
- TCP状态机
- TCP 状态机
- tcp状态机
- tcp状态机
- TCP状态机
- TCP状态机
- 关于状态机的一点心得体会
- 关于Qt状态机的记录
- 关于状态机的思想问题
- tcp状态机中time_wait状态的理解
- TCP拥塞状态机的实现(上)
- TCP拥塞状态机的实现(中)
- Java多线程那些事(二)
- Fab CEO:我在创办4家公司中学到的90件事
- MySQL5.5服务器命令选项中文版(InnoDB存储引擎)
- pragma warning
- Request Response对象
- 关于TCP的状态机
- listControl 控件debug assrtion failed!
- log4j 实例详解
- NSArray和NSMutableArray的常用方法
- c#利用qq的smtp服务器发邮件
- MySQL5.5服务器命令选项中文版(服务器部分)
- Tab组件的使用
- Apache TomEE 1.5版发布
- POJ3749 破译密码