码迷,mamicode.com
首页 > 其他好文 > 详细

TCP/IP握手

时间:2015-08-21 21:00:10      阅读:184      评论:0      收藏:0      [点我收藏+]

标签:

参考 (讲的特别好)
http://www.2cto.com/net/201209/157577.html
http://www.cnblogs.com/hnrainll/archive/2011/10/14/2212415.html
 
简化一下,其实有两个序列,客户端发送X,服务器发送Y。三次握手分别是
客户端:发送X
服务端:发送Y, 确认X+1 
客户端:发送X+1,确认Y+1
 
TCP三次握手,四次挥手的状态变化,对着图看吧,加深印象。
三次握手如下:
技术分享
(此图第三次握手的ack应该等于y+1,而不是y,但不影响解这题)
四次挥手如下:
技术分享
 
TCP之RST发送场景
 
1.connect一个不存在的端口;
 
2.向一个已经关掉的连接send数据;
 
3.向一个已经崩溃的对端发送数据(连接之前已经被建立);
 
4.close(sockfd)时,直接丢弃接收缓冲区未读取的数据,并给对方发一个RST。这个是由SO_LINGER选项来控制的;
 
5.a重启,收到b的保活探针,a发rst,通知b。
 
TCP socket在任何状态下,只要收到RST包,即可进入CLOSED初始状态。
 
值得注意的是RST报文段不会导致另一端产生任何响应,另一端根本不进行确认。收到RST的一方将终止该连接。程序行为如下:
 
阻塞模型下,内核无法主动通知应用层出错,只有应用层主动调用read()或者write()这样的IO系统调用时,内核才会利用出错来通知应用层对端RST。
 
非阻塞模型下,select或者epoll会返回sockfd可读,应用层对其进行读取时,read()会报错RST。
 
 

TCP/IP握手

标签:

原文地址:http://www.cnblogs.com/chuiyuan/p/4748868.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!