【Linux】三次握手

TCP连接通过三次握手建立,客户端发送SYN报文开始,服务器确认并发送SYN+ACK,最后客户端发送ACK完成握手。三次握手旨在确保双方准备好通信、避免失效请求和资源浪费。若第二阶段服务器端口未开或监听队列满,可能导致握手异常。SYN泛洪攻击发生在第二次握手,恶意客户端发送大量SYN请求,耗尽服务器资源。
摘要由CSDN通过智能技术生成

客户端connect()向服务器发起连接,客户端和服务器通过三次握手建立连接,被服务器listen()开机后监听到后将套接字放到listen()已完成三次握手队列中。

第一次握手:建立连接时,客户端向服务器发送SYN报文(seq = j),并进入SYN_SENT状态,等待服务器确认。

第二次握手:服务器收到SYN报文,必须确认客户的SYN(即发送ACK报文,ack = j+1),同时自己也发送一个SYN报文(seq = k),即ACK+SYN报文,此时服务器进入SYN_RECV状态。

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

未完成三次握手队列:在三次握手协议中,服务器listen()维护一个未连接队列,该队列为每个客户端的SYN包(syn=j)开设一个条目,该条目表明服务器已收到SYN包,并向客户发出确认,正在等待客户的确认包。这些条目所标识的连接在服务器处SYN_RECV状态,当服务器收到客户的确认包时,删除该条目,服务器进入ESTABLISHED状态。

三次握手示意图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值