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

浅析TCP

时间:2017-08-23 20:03:09      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:告诉   浅析   syn   客户   server   客户端   tab   tcp   接受   

一.TCP三次握手和四次挥手的全过程

三次握手:

第一次握手:客户端发送syn包(syn=x)到服务器,并进入SYN_SEND状态,等待服务器确认;

第二次握手:服务器收到syn包,必须确认客户的SYN(ack=x+1),同时自己也发送一个SYN包(syn=y),即SYN+ACK包,此时服务器进入SYN_RECV状态;

第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=y+1),此包发送完毕,客户端和服务器进入ESTABLISHED状态,完成三次握手。

握手过程中传送的包里不包含数据,三次握手完毕后,客户端与服务器才正式开始传送数据。理想状态下,TCP连接一旦建立,在通信双方中的任何一方主动关闭连接之前,TCP 连接都将被一直保持下去。

四次握手

与建立连接的“三次握手”类似,断开一个TCP连接则需要“四次握手”。

第一次挥手:主动关闭方发送一个FIN,用来关闭主动方到被动关闭方的数据传送,也就是主动关闭方告诉被动关闭方:我已经不 会再给你发数据了(当然,在fin包之前发送出去的数据,如果没有收到对应的ack确认报文,主动关闭方依然会重发这些数据),但是,此时主动关闭方还可 以接受数据。

第二次挥手:被动关闭方收到FIN包后,发送一个ACK给对方,确认序号为收到序号+1(与SYN相同,一个FIN占用一个序号)。
第三次挥手:被动关闭方发送一个FIN,用来关闭被动关闭方到主动关闭方的数据传送,也就是告诉主动关闭方,我的数据也发送完了,不会再给你发数据了。
第四次挥手:主动关闭方收到FIN后,发送一个ACK给被动关闭方,确认序号为收到序号+1,至此,完成四次挥手。

技术分享

二.注意几点

1.关于建立连接时SYN超时: server端接到client发出的额SYN后回了SYN-ACK后客户端掉线了,则服务器就收不到客户端回复的ACK,

此时服务器回重传SYN-ACK,在Linux下默认重传次数为5次, 用时63s,之后TCP才会断开此连接

2.关于SYN Flood攻击

原理: 恶意向服务器端口发送大量SYN包,大量消耗服务器资源,不断造成SYN超时等,;有固定原地址攻击,变化原地址(伪地址)

浅析TCP

标签:告诉   浅析   syn   客户   server   客户端   tab   tcp   接受   

原文地址:http://www.cnblogs.com/zhaodun/p/7419619.html

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