3

我正在使用cherrypy 作为网络服务器。它为我的应用程序提供了良好的性能,但它存在一个非常大的问题。几个小时后,cherrypy 崩溃,说明由于打开的文件太多,它无法创建套接字:

[21/Oct/2008:12:44:25] ENGINE HTTP Server 
cherrypy._cpwsgi_server.CPWSGIServer(('0.0.0.0', 8080)) shut down    
[21/Oct/2008:12:44:25] ENGINE Stopped thread '_TimeoutMonitor'.    
[21/Oct/2008:12:44:25] ENGINE Stopped thread 'Autoreloader'.    
[21/Oct/2008:12:44:25] ENGINE Bus STOPPED    
[21/Oct/2008:12:44:25] ENGINE Bus EXITING    
[21/Oct/2008:12:44:25] ENGINE Bus EXITED    
Exception in thread HTTPServer Thread-3:    
Traceback (most recent call last):    
  File "/usr/lib/python2.3/threading.py", line 436, in __bootstrap    
    self.run()    
  File "/usr/lib/python2.3/threading.py", line 416, in run   
    self.__target(*self.__args, **self.__kwargs)    
  File "/usr/lib/python2.3/site-packages/cherrypy/process/servers.py", line 73, in 
_start_http_thread    
    self.httpserver.start()    
  File "/usr/lib/python2.3/site-packages/cherrypy/wsgiserver/__init__.py", line 1388, in start
    self.tick()    
  File "/usr/lib/python2.3/site-packages/cherrypy/wsgiserver/__init__.py", line 1417, in tick    
    s, addr = self.socket.accept()    
  File "/usr/lib/python2.3/socket.py", line 167, in accept    
    sock, addr = self._sock.accept()    
error: (24, 'Too many open files')    
[21/Oct/2008:12:44:25] ENGINE Waiting for child threads to terminate..

我试图弄清楚发生了什么。我的应用程序没有打开任何文件或任何套接字等。我的文件只打开了几个 berkeley dbs。我进一步调查了这个问题。我在 /proc/4536/fd/ 中看到了我的cherrypy 进程使用的文件描述符,ID 为 4536 所有套接字都处于 CLOSE_WAIT 状态。我使用以下命令获得了此信息:

netstat -ap | grep "4536" | grep CLOSE_WAIT | wc -l

CLOSE_WAIT 状态意味着远程客户端已经关闭了连接。为什么cherrypy然后不关闭套接字并释放文件描述符?我能做些什么来解决这个问题?

我尝试玩以下游戏:

cherrypy.config.update({'server.socketQueueSize': '10'})

我认为这会将随时打开的套接字数量限制为 10,但它根本没有效果。这是我设置的唯一配置,因此,其余配置保持其默认值。

有人可以对此有所了解吗?你认为它是cherrypy中的一个错误吗?我该如何解决?有没有办法自己关闭这些套接字?

以下是我的系统信息:

CherryPy-3.1.0

蟒蛇2.3.4

红帽企业 Linux ES 第 4 版(Nahant 更新 7)

提前致谢!

4

1 回答 1

4

我想你正在存储(在内存中)一些引用套接字的数据;例如,如果您将请求对象存储在任何地方,则可能会这样做。

关闭套接字的最后机会是当它们被垃圾收集时;如果您正在做任何会阻止垃圾收集到达它们的事情,那就是您的问题。我建议你尝试用 CherryPy 编写的 Hello World 程序来重现;如果你不能在那里重现,你知道它在你的代码中——寻找你保存可以(直接或以其他方式)引用套接字的信息的地方。

于 2008-10-21T19:22:18.693 回答