Apache套接字没有关闭?

时间:2008-10-02 17:40:38

标签: python apache urllib2 cherrypy mod-proxy

我有一个使用CherryPy编写的Web应用程序,它在127.0.0.1:4321本地运行。我们使用mod-rewrite和mod-proxy让Apache充当反向代理; Apache还处理我们的SSL加密,最终可能用于传输所有静态内容。

这一切都适用于小型工作负载。但是,我最近使用urllib2编写了一个压力测试脚本,可以模拟100个客户端的工作负载。一段时间后,每个客户端从Apache收到503错误,表明Apache无法连接到127.0.0.1:4321。 CherryPy运行正常,但我的Apache错误日志显示如下行:

[Thu Oct 02 12:55:44 2008] [error] (OS 10048)Only one usage of each socket address (protocol/network address/port) is normally permitted. : proxy: HTTP: attempt to connect to 127.0.0.1:4321 (*) failed

谷歌搜索此错误表明Apache可能用完了套接字文件描述符。由于我只运行了100个客户端,这意味着我的urllib2连接和Apache之间的连接没有被关闭(我肯定在.close()的返回值上调用urlopen ,或Apache和CherryPy之间。

我已确认我的urllib2请求正在发送HTTP Connection: close标头,但如果重要的话,Apache配置了KeepAlive On

如果重要,我使用的是Python 2.5,Apache 2.2,CherryPy 3.0.3,服务器在Windows Server 2003上运行。

那么我的下一步是什么来阻止这个问题?

2 个答案:

答案 0 :(得分:5)

您可以运行netstat命令,看看是否有一堆处于TIME_WAIT状态的套接字。根据您的MaxUserPort设置,您可能会严重限制可用端口的数量。此外,TcpTimedWaitDelay通常设置为240秒,因此使用的任何套接字都不能在四分钟内重复使用。

这里有更多好消息 - > http://smallvoid.com/article/winnt-tcpip-max-limit.html

答案 1 :(得分:5)

如果Apache和CP之间存在问题,

SetEnv proxy-nokeepalive 1可能会立即告诉您。有关详细信息,请参阅mod_proxy docs