mongodb引起内存泄露问题

好久不见,最近程序上有些问题,需要记录一下.

比如mongodb引起的内存泄露问题.

起因需要开多端口复制一套tomcat程序,来进行负载,和备份.但是free 一看根本内存都吃没了.

本来机器上就没啥大程序,而且4G的内存应该很富裕的,但是却被tomcat占去了将近3G的内存,这让我很疑惑(虽然一个tomcat里的项目很多,但是也不应该这么大内存的消耗.),

然后jmap dump了一份进行分析

分析结果如下图

mongodb引起内存泄露问题_第1张图片

我去,怎么会有这么多未释放的连接?

让它自己分析一下:

mongodb引起内存泄露问题_第2张图片

看到了吧,全是mongodb的未释放连接...这真会玩...

好了,转回来.

对于mongodb连接用完就释放的问题,我记得有这么个比喻:

当使用mongodb的连接池时,好比园丁浇水,从井里打了一桶水,然后舀了一勺子水浇花,然后把水给倒回井里...

虽然比喻很恰当,但是不释放的话 内存真的吃不消.所以

用完时候 还是请mongoClient.close();

谢谢.

你可能感兴趣的:(mongodb)