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

    18.6.1  2MSL 等待状态 
    
    TIME_WAIT 状态也称为2MSL等待状态,每个具体TCP实现必须选择一个报文段最大生存时间MSL
    
    它是任何报文段被丢弃前在网络内的最长时间。
    
    我们知道这个时间是有限的,因为TCP报文段以IP数据报在网络内传输,
    
    而IP数据报则有限制其生存时间的TTL字段
    
    RFC 793 [Postel 1981c] 指出MSL为2分钟。然而,实现中的常用值是30秒,1分钟,
    或2分钟。
    
    从第8章我们知道在实际应用中,对IP数据报TTL的限制是基于跳数,而不是定时器
    
    
    对一个具体实现所给定的MSL值,处理的原则是:
    
    这种2 M S L等待的另一个结果是这个 T C P连接在2 M S L等待期间,定义这个连接的插口
    (客户的I P地址和端口号,服务器的 I P地址和端口号)不能再被使用。这个连接只能在 2 M S L
    结束后才能再被使用
    
    遗憾的是,大多数 T C P实现(如伯克利版)强加了更为严格的限制。在 2 M S L等待期间,
    插口中使用的本地端口在默认情况下不能再被使用。我们将在下面看到这个限制的例子。
    
    然而,对于服务器,情况就有所不同,因为服务器使用熟知端口。如果我们终止一个已
    经建立连接的服务器程序,并试图立即重新启动这个服务器程序,服务器程序将不能把它的
    这个熟知端口赋值给它的端点,因为那个端口是处于 2 M S L连接的一部分。在重新启动服务器
    程序前,它需要在1 ~ 4分钟。
    
    
    
    node1:/root/test#python test.py
    Traceback (most recent call last):
      File "test.py", line 7, in <module>
        s.bind(ip_port)#绑定地址
      File "<string>", line 1, in bind
    socket.error: [Errno 98] Address already in use
    
    
    2020年 02月 19日 星期三 23:21:00 CST
    tcp        0      0 192.168.137.2:8080          192.168.137.1:49464         TIME_WAIT   
      
    2020年 02月 19日 星期三 23:21:59 CST
    tcp        0      0 192.168.137.2:8080          192.168.137.1:49464         TIME_WAIT   
    
    
    
    当重新启动服务器程序时,程序报告一个差错信息说明不能绑定它的熟知端口,因为该端口
    已被使用(即它处于2 M S L等待)
    
    
    
    某些实现和A P I提供了一种避开这个限制的方法。使用插口A P I时,可说明其中的
    S O _ R E U S E A D D R选项。它将让调用者对处于2 M S L等待的本地端口进行赋值,但我们
    将看到TCP原则上仍将避免使用仍处于2MSL连接中的端口。
    
    
    S O _ R E U S E A D D R选
    
    
    解决办法:
    
    s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
    
  • 相关阅读:
    最短路径BellmanFord , Dijsktra
    minhash
    eclipse 中使用tomcat
    http 服务
    MongoDB小记
    java post 请求
    hadoop拾遗(五)---- mapreduce 输出到多个文件 / 文件夹
    weka数据挖掘拾遗(二)---- 特征选择(IG、chi-square)
    weka数据挖掘拾遗(一)---- 生成Arff格式文件
    基于SimHash的微博去重
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13348573.html
Copyright © 2011-2022 走看看