zoukankan      html  css  js  c++  java
  • 18.6.1 2MSL等待状态

    18.6.1  2MSL等待状态
    
    TIME_WAIT 状态也称为2MSL等待状态。
    
    每个具体TCP 实现必须选择一个报文段最大生存时间MSL()
    
    对一个具体实现所给定的MSL值,处理的原则是:
    
    当TCP执行一个主动关闭,并发回最后一个ACK,
    
    该练级必须在TIME_WAIT状态停留的时间为2倍的MSL。
    
    
    这种2MSL等待的另一个结果是这个TCP连接在2MSL等待期间,定义这个连接的插口
    
    (客户的IP地址和端口号,服务器的IP地址和端口好)不能再被使用。这个连接只能
    
    在2MSL结束后才能被使用
    
    在2MSL等待期间,插口中使用的本地端口在默认情况下不能再被使用。
    
    于服务器,情况就有所不同,因为服务器使用熟知端口。如果我们终止一个已
    经建立连接的服务器程序,并试图立即重新启动这个服务器程序,服务器程序将不能把它的
    这个熟知端口赋值给它的端点,因为那个端口是处于 2 M S L连接的一部分。在重新启动服务器
    程序前,它需要在1 ~ 4分钟。
    
    #s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
    s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 0)
    
    node1:/root/test#python t2.py 
    Traceback (most recent call last):
      File "t2.py", line 9, in <module>
        s.bind(ip_port)#绑定地址
      File "<string>", line 1, in bind
    socket.error: [Errno 98] Address already in use
    
    node1:/root#netstat -na | grep 8080
    tcp        0      0 192.168.137.2:8080          192.168.137.1:55007         TIME_WAIT  
  • 相关阅读:
    网卡工作状态检测
    Soap/Web Service执行效率的思考
    Soap/Web Service执行效率的思考
    判断一个字符是否为汉字的最佳方法[转]
    Kafka数据可靠性深度解读
    HTTP 5XX代码理解
    图解:原来这就是网络
    架构设计原则
    Kafka
    Nginx 之 proxy_pass详解
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13348557.html
Copyright © 2011-2022 走看看