mongodb引起内存泄露问题

    xiaoxiao2022-06-28  31

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

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

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

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

    然后jmap dump了一份进行分析

    分析结果如下图

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

    让它自己分析一下:

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

    好了,转回来.

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

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

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

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

    谢谢.

    转载请注明原文地址: https://ju.6miu.com/read-1124579.html

    最新回复(0)