cloudfoundry的too many open file错误的分析和解决

在vmware的paas平台cloudfoundry布署了一个价格抓取程序,隔一段时间会抓取价格进行处理。

程序运行一段时间就会报too many open file错误。

程序对打开的文件资源都进行了正确回收释放,而且在本机windows环境布署的tomcat7上运行正常。

在官网论坛上查找原因分析,

cloudfoundry平台基于linux,有filedescriptor数量的限制,

免费的是256,如果超过256就会报too many open file。

程序使用httpclient-4.1.2开源包的HttpClient.execute(get);读取网络数据

此函数读取网络数据要创建filedescriptor,

虽然用完就释放了,但在操作系统上并没有实时释放,

所以再次使用会报too many open file错误。

解决:

简单的办法,用单例模式管理HttpClient对象,使用同一个HttpClient对象。

更好的办法,使用资源池管理HttpClient对象,像管理数据库连接池一样管理filedescriptor对象或者HttpClient对象。

至此,问题得到解决。

 

posted @ 2012-03-12 10:07  gmartincn  阅读(296)  评论(0编辑  收藏  举报