服务器端close_wait模拟

服务端192.168.137.3上定义接口:
def testtimedout(req):
   time.sleep(20)
   out={"a":{'ip':'20.20.20.1','db':'aaa'},"c":{'ip':'1.1.1.1','db':'bbb'},"e":{'ip':'2.2.2.2','db':'cccc'}}
   return HttpResponse(json.dumps(out), content_type="application/json")
   

# !/usr/bin/env python
# -*- coding: utf-8 -*-
import urllib2
import urllib
import cookielib
import json
import httplib
import re
import requests
import os
import time
 
import requests, requests.utils, pickle
 
try:
    import cookielib  # 兼容Python2
except:
    import http.cookiejar as cookielib
 
from requests.packages.urllib3.exceptions import InsecureRequestWarning
 
requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
url='http://192.168.137.3:9000/testtimedout'
while True:
   try:
    s = requests.session()
    r = s.get(url, verify=False,timeout=5)
    print r.content
   except:
       print '222222222'




服务器端:

Last login: Mon Aug 26 16:04:31 2019 from 192.168.137.1
node2:/root#netstat -na |grep 9000
tcp        0      0 0.0.0.0:9000                0.0.0.0:*                   LISTEN      



客户端:

C:\Users\TLCB>netstat -na | findstr 9000

C:\Users\TLCB>




# !/usr/bin/env python
# -*- coding: utf-8 -*-
import urllib2
import urllib
import cookielib
import json
import httplib
import re
import requests
import os
import time

import requests, requests.utils, pickle

try:
    import cookielib  # 兼容Python2
except:
    import http.cookiejar as cookielib

from requests.packages.urllib3.exceptions import InsecureRequestWarning

requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
url = 'http://192.168.137.3:9000/testtimedout'
while True:
    try:
        s = requests.session()
        r = s.get(url, verify=False, timeout=5)
        print r.content
        r.close()
    except:
        print '222222222'




服务端close_wait
node2:/root#netstat -na |grep 9000 | grep -i close
tcp        1      0 192.168.137.3:9000          192.168.137.1:53583         CLOSE_WAIT  
tcp        1      0 192.168.137.3:9000          192.168.137.1:53578         CLOSE_WAIT  
tcp        1      0 192.168.137.3:9000          192.168.137.1:53598         CLOSE_WAIT  
tcp        1      0 192.168.137.3:9000          192.168.137.1:53571         CLOSE_WAIT  
tcp        1      0 192.168.137.3:9000          192.168.137.1:53586         CLOSE_WAIT  
tcp        1      0 192.168.137.3:9000          192.168.137.1:53574         CLOSE_WAIT  
tcp        1      0 192.168.137.3:9000          192.168.137.1:53588         CLOSE_WAIT  
tcp        1      0 192.168.137.3:9000          192.168.137.1:53592         CLOSE_WAIT  
tcp        1      0 192.168.137.3:9000          192.168.137.1:53596         CLOSE_WAIT  
node2:/root#netstat -na |grep 9000 | grep -i close | wc -l

客户端

C:\Users\TLCB>netstat -na | findstr 9000
  TCP    192.168.137.1:54556    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54558    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54560    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54562    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54564    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54568    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54570    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54574    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54576    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54578    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54580    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54582    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54591    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54593    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54595    192.168.137.3:9000     FIN_WAIT_2
  TCP    192.168.137.1:54599    192.168.137.3:9000     FIN_WAIT_2
  
客户端主动关闭联系,服务端堵塞导致

servlet由于得不到数据库连接而阻塞了,这个客户端的请求就一直等待,客户端使用httpclient设置了5s的请求超时时间,


那么超时之后就会抛出异常,关闭连接,关闭连接导致客户端发送了FIN报文,


我这边的TCP/IP返回了ACK报文,但是由于处理请求的线程还处于阻塞的状态,所以当前的连接状态时CLOSE_WAIT。


发现这个状态是由于客户端关闭了socket连接,发送了FIN报文,服务端也发送了ACK报文,此时客户端处于FIN_WAIT_2状态,服务端处于CLOSE_WAIT状态,如下图:

 

服务器端大量的close_wait状态通常是由于服务器程序没有正确地关闭网络连接导致的。为了解决这个问题,可以采取以下几种方法: 1. 关闭连接前确保双方都关闭了连接:在服务器程序中,确保在关闭连接之前发送一个关闭请求给客户端,要求其关闭连接。这样可以避免服务器端出现大量的close_wait状态。 2. 设置合适的超时时间:在服务器程序中,为每个网络连接设置一个合适的超时时间。如果连接在超过一定时间内没有活动,那么服务器可以主动关闭连接,避免出现close_wait状态。 3. 使用连接池管理连接:通过使用连接池管理服务器和客户端之间的连接,能够更好地控制连接的创建和关闭。在每个连接使用完毕后,将其放回连接池中,而不是立即关闭。这样可以避免频繁创建和关闭连接,减少close_wait状态的产生。 4. 检查服务器程序的bug:关闭连接后产生大量的close_wait状态可能是服务器程序中存在的bug导致的。检查服务器程序的代码,确保在每个连接关闭的地方都正确处理了关闭连接的操作,避免出现资源泄漏问题。 综上所述,解决服务器端大量close_wait状态的问题需要深入分析服务器程序的代码和连接管理机制,确保连接在合适的时候被关闭,避免出现close_wait状态。同时,合理设置超时时间和使用连接池等方法也可以减少close_wait状态的产生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

scan724

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值