好久不见,最近程序上有些问题,需要记录一下.
比如mongodb引起的内存泄露问题.
起因需要开多端口复制一套tomcat程序,来进行负载,和备份.但是free 一看根本内存都吃没了.
本来机器上就没啥大程序,而且4G的内存应该很富裕的,但是却被tomcat占去了将近3G的内存,这让我很疑惑(虽然一个tomcat里的项目很多,但是也不应该这么大内存的消耗.),
然后jmap dump了一份进行分析
分析结果如下图
我去,怎么会有这么多未释放的连接?
让它自己分析一下:
看到了吧,全是mongodb的未释放连接...这真会玩...
好了,转回来.
对于mongodb连接用完就释放的问题,我记得有这么个比喻:
当使用mongodb的连接池时,好比园丁浇水,从井里打了一桶水,然后舀了一勺子水浇花,然后把水给倒回井里...
虽然比喻很恰当,但是不释放的话 内存真的吃不消.所以
用完时候 还是请mongoClient.close();
谢谢.
转载请注明原文地址: https://ju.6miu.com/read-1124579.html