TCP三次握手相关面试题

1.三次握手

在这里插入图片描述
最初客户端和服务端都处于 CLOSED(关闭) 状态。本例中 A(Client) 主动打开连接,B(Server) 被动打开连接。

一开始,B的TCP服务器进程首先创建传输控制块TCB,准备接受客户端进程的连接请求。然后服务器进程就处于LISTEN状态,等待客户端的连接请求。

第一次握手:A的TCP客户端进程也是首先创建传输控制块TCB,然后向B发送连接请求报文,报文的同步位SYN=1,表示这是一个连接请求报文段。并选择一个初始序号seq=x。TCP规定,SYN=1的报文段不能携带数据。但要消耗掉一个序号。这时,TCP客户端进入SYN-SENT状态。

第二次握手:B收到连接请求后,如同意建立连接,则向A发送确认。在确认报文段中,将SYN与ACK都置为1,确认好为x+1,同时为自己选择一个初始序号seq=y。同理,这个报文段也不能携带数据,且需要消耗一个序号。这时,TCP服务端进程进入SYN-RCVD状态。

第三次握手:TCP客户端收到确认信息后,还要向B发送确认。确认报文段ACK置为1,确认号为y+1,自己的序号为x+1。这时ACK报文段可携带数据。不携带数据则不消耗序号。此时TCP连接已建立,A进入ESTABLISHED状态。

2.为什么两次握手不可以

为了防止已失效的连接请求报文段又传送到了B。如果没有第三次握手,那么这样会导致B发出确认后就认为连接已建立,并等待数据到来,造成资源的浪费。

3.为什么不需要四次握手

完全可靠的通信协议是不存在的。三次握手之后,通信双方都确认可以进行通信,再增加握手次数也不能保证之后的通信完全可靠,所以没有必要再握手。

4.Server 端收到 Client 端的 SYN 后,为什么还要传回 SYN

为了告诉客户端,服务端接收到的确实就是客户端所发送的连接请求报文段。

5. 传回了SYN,为什么还要传ACK

双方通信无误必须是两者互相发送信息都无误。传了SYN,证明发送方到接收方的通道没问题,而接收方到发送方的通道还需要ACK来进行验证

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值