我在生产中使用playframework 2.0,并且我看到相应java进程打开的文件数量迅速增加。我将一个进程的打开文件的默认允许数量从1024改为4096,但这只是延迟了一个问题,一段时间后打开文件的数量变得如此之大,以至于服务器速度变慢,有时甚至出现一个“打开太多的文件太多文件“出现在日志中。如何在playframework 2中配置保持活动超时
我使用的是Ubuntu的服务器12.04,sun jdk 1.7.0_09。
lsof
命令显示几乎所有打开的文件都是为用户连接创建的套接字,因此我得出结论,playframework使用的Netty服务器保持大量打开的连接。据我所知,我应该改变Netty服务器的保持活动行为,例如,设置一个低保活超时。我如何在playframework 2.0中配置它?或者可能是其他问题?如果需要,我可以提供任何配置。
UPD:这里有点lsof -aPn -p 12251
的输出。我删IPS的某些部分与***
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
java 12251 root 324u IPv6 279502 0t0 TCP 10.127.0.***:80->***.***.65.137:51506 (ESTABLISHED)
java 12251 root 325u IPv6 286749 0t0 TCP 10.127.0.***:80->***.***.18.121:1624 (ESTABLISHED)
java 12251 root 327u IPv6 287220 0t0 TCP 10.127.0.***:80->***.***.126.210:49244 (ESTABLISHED)
java 12251 root 330u IPv6 279289 0t0 TCP 10.127.0.***:80->***.***.65.155:12444 (ESTABLISHED)
java 12251 root 331u IPv6 285609 0t0 TCP 10.127.0.***:80->***.***.33.233:2552 (ESTABLISHED)
java 12251 root 332u IPv6 285610 0t0 TCP 10.127.0.***:80->***.***.33.233:2554 (ESTABLISHED)
java 12251 root 333u IPv6 287236 0t0 TCP 10.127.0.***:80->***.***.90.20:16040 (ESTABLISHED)
java 12251 root 334u IPv6 284047 0t0 TCP 10.127.0.***:80->***.***.195.2:1175 (ESTABLISHED)
java 12251 root 335u IPv6 279357 0t0 TCP 10.127.0.***:80->***.***.65.137:51273 (ESTABLISHED)
java 12251 root 336u IPv6 279988 0t0 TCP 10.127.0.***:80->***.***.65.137:51287 (ESTABLISHED)
你确定它来自Play吗?你不在你的应用中生成某种文件吗? –
我不生成或从文件系统读取任何文件,所有资源都会自动打包在应用程序jar中。如果我通过'lsof'工具测试打开哪些文件,我会发现这些文件是针对很多不同IP的unix套接字,所以我认为这些套接字已连接到用户。例如,它们不符合我的数据库的连接。 –