我有一个使用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上运行。
那么我的下一步是什么来阻止这个问题?
答案 0 :(得分:5)
您可以运行netstat命令,看看是否有一堆处于TIME_WAIT状态的套接字。根据您的MaxUserPort设置,您可能会严重限制可用端口的数量。此外,TcpTimedWaitDelay通常设置为240秒,因此使用的任何套接字都不能在四分钟内重复使用。
这里有更多好消息 - > http://smallvoid.com/article/winnt-tcpip-max-limit.html
答案 1 :(得分:5)
SetEnv proxy-nokeepalive 1
可能会立即告诉您。有关详细信息,请参阅mod_proxy docs。