【发布时间】: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