• 三次握手四次挥手


    第一次握手:建立连接时,客户端发送syn包(syn=j)到,
    并进入SYN_SENT状态,等待服务器确认;SYN:同步序列编号(Synchronize Sequence Nu服务器mbers)。
    第二次握手服务器收到syn包,必须确认客户的SYN(ack=j+1),
    同时自己也发送一个SYN包(syn=k),即SYN+ACK包,
    此时服务器进入SYN_RECV状态;
    第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=k+1),此包发送完毕,
    客户端和服务器进入ESTABLISHED(TCP连接成功)状态,
    完成三次握手。
     
    完成三次握手,客户端与服务器开始传送数据,在上述过程中,
    还有一些重要的概念:未连接队列
    三次握手协议中,服务器维护一个未连接队列,
    该队列为每个客户端的SYN包(syn=j)开设一个条目,
    该条目表明服务器已收到SYN包,并向客户端发出确认,
    正在等待客户端的确认包。这些条目所标识的连接在服务器处于SYN_RECV状态,当服务器收到客户端的确认包时,删除该条目,
    服务器进入ESTABLISHED状态。
     
    关闭TCP连接:改进的三次握手(四次挥手)
    对于一个已经建立的连接,TCP使用改进的三次握手来释放连接
    (使用一个带有FIN附加标记的报文段)。TCP关闭连接的步骤如下:
    第一步,当主机A的应用程序通知TCP数据已经发送完毕时,
    TCP向主机B发送一个带有FIN附加标记的报文段(FIN表示英文finish)。
    第二步,主机B收到这个FIN报文段之后,
    并不立即用FIN报文段回复主机A,而是先向主机A发送一个确认序号ACK,同时通知自己相应的应用程序:对方要求关闭连接
    (先发送ACK的目的是为了防止在这段时间内,对方重传FIN报文段)。
    第三步,主机B的应用程序告诉TCP:我要彻底的关闭连接,
    TCP向主机A发送一个FIN报文段。
    第四步,主机A收到这个FIN报文段后,
    向主机B发送一个ACK表示连接彻底释放。
     
    为什么要采用三次握手,两次不行吗?
     
     
     为什么a在time-wait状态必须等待2msl的时间呢?两个理由
     
     
     
     
    保活计时器:
    设想有这样的情况:客户端已主动与服务器建立了TCP连接,但后来客户端的主机突然出现故障。
    通常设为2小时。若2小时没有收到客户端的数据,服务器就发送一个探测报文段,以后则每隔75分钟发送一次。若一连发送10个探测报文段后仍无客户端的响应,服务器就认为客户端出现了故障,接着就关闭这个连接。
     
     
     
     
     
    为什么连接的时候是三次握手,关闭的时候却是四次挥手?
    答:因为当Server端收到Client端的SYN连接请求报文后,可以直接发送SYN+ACK报文。其中ACK报文是用来应答的,SYN报文是用来同步的。但是关闭连接时,当Server端收到FIN报文时,很可能并不会立即关闭SOCKET,所以只能先回复一个ACK报文,告诉Client端,"你发的FIN报文我收到了"。只有等到Server端所有的报文都发送完了,才能发送FIN报文,因此不能一起发送。故需要四步握手。
     
    为什么TIME_WAIT状态需要经过2MSL(最大报文段生存时间)才能返回到CLOSE状态?
    答:虽然按道理,四个报文都发送完毕,可以直接进入CLOSE状态了,但是毕竟假象网络是不可靠的,有可能最后一个ACK丢失。所以TIME_WAIT状态就是用来重发可能丢失的ACK报文。

  • 相关阅读:
    PHP trim() 函数
    php 计算2个日期的相差天数
    php date('Y-n-j')的和date('Y-m-d')的区别
    转移服务器
    Invalid argument supplied for foreach()解决办法
    wordpress 后台忘记密码怎么办
    qrcode js插件生成微信二维码
    thinkphp5 注释
    tp5 新增完数据,获取id
    resstFul服务文件上传下载
  • 原文地址:https://www.cnblogs.com/limengyao/p/8604407.html
Copyright © 2020-2023  润新知