【问题标题】:How can I force socket opened with python to close?如何强制使用 python 打开的套接字关闭?
【发布时间】:2012-11-08 11:13:53
【问题描述】:

我目前正在使用这个库对我设置的 kafka 服务器进行压力测试:https://github.com/dsully/pykafka

import kafka
import time

def test_kafka_server(n=1):
    for i in range(0,n):
        producer = kafka.producer.Producer('test',host='10.137.8.192')
        message = kafka.message.Message(str(time.time()))
        producer.send(message)
        producer.disconnect()

def main():
    test_kafka_server(100000)

if __name__ == '__main__':
    main()

最终发生的事情是我最终使我自己的本地计算机超载。

我得到 error 10055,根据 google,这意味着 “Windows 已用完 TCP/IP 套接字缓冲区,因为同时打开了太多连接。” 根据对于 netstat,producer.disconnect() 并没有关闭套接字,而是将其置于TIME_WAIT 状态。

ipython 调试器指向这一行:

C:\Python27\lib\socket.pyc in meth(name, self, *args)
    222     proto = property(lambda self: self._sock.proto, doc="the socket protocol")
    223 
--> 224 def meth(name,self,*args):
    225     return getattr(self._sock,name)(*args)
    226 

作为罪魁祸首,但这似乎会导致在比我感到舒服的更低级别上搞砸事情。

我已经搜索并找到了这个Python socket doesn't close connection properly,它建议这样做:

setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)

所以,我在 io.py 文件中使用该选项重建了 pykafka 库:

  def connect(self):
    """ Connect to the Kafka server. """
    global socket
    self.socket = socket.socket()
    self.socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
    self.socket.connect((self.host, self.port))

我仍然遇到同样的错误。

我没有把 setsockopt 线放在正确的位置吗?还有什么我可以尝试的吗?

【问题讨论】:

标签: python sockets apache-kafka


【解决方案1】:

您所描述的是套接字级别的正常 TCP 行为。当用户级程序关闭套接字时,内核不会立即释放套接字。进入TIME_WAIT状态:

TIME-WAIT(无论是服务器还是客户端)表示等待足够 确保远程 TCP 收到确认的时间 它的连接终止请求。 [根据 RFC 793 连接 可以在 TIME-WAIT 中停留最多四分钟,称为 MSL (最大段生命周期)。

所以套接字是关闭的。 socket.SO_REUSEADDR 用于侦听器(服务器),不影响客户端连接。嗯,确实在绑定socket的时候用到了。

【讨论】:

    猜你喜欢
    • 2017-04-22
    • 2016-02-14
    • 1970-01-01
    • 1970-01-01
    • 2013-09-22
    • 1970-01-01
    • 2011-05-26
    • 2017-12-24
    • 1970-01-01
    相关资源
    最近更新 更多