• 一个内存增长问题的分析和处理(三)


    和框架部门的同事一起,经过valgrind大量的测试和验证,并没有发现有确切的内存泄露的代码段。对于C和C++程序,出现内存增长,可能我们很自然的就去内存泄露方面去思考,有时候,这种方向可能不一定对。

            在解决这个问题的过程中,生成上又出现了另外一个内存增长的问题。这次的现象很明显,就是一个进程,能清晰的看到内存在不断的增长,进程停止后,内存就直接释放,下次还是会缓慢增长。大家的思路就是检查下代码,看看有没有内存泄露,由于程序中没有使用new 和 malloc的地方,所以不存在直接的内存操作。这样就比较难定位内存泄露,并且valgrind的信息,也看不出来有内存泄露。后来经过分析可能是程序是通过while(true)的写法来对数据进行循环扫描处理的,而在这个中间,会把对内存数据库的操作信息,存放在Session中,由于没有调用清理session的接口,所以session中的数据结构越来越大,所以才导致内存不断的增长。后来修改了代码,调用了清理Session的接口后,内存恢复正常。

            有了这个问题的思路,我又回过头来看之前遇到的这个问题:

            1、这个问题出现的情况,是数据库存在异常的情况

       2、看日志,是不断的去连接,可能是数据库连接没释放

         3、如果数据库连接没释放,会不会Session数据不断地增加呢

             如何验证这个问题,是一个比较困难的事情,我试了下,当数据库抛出异常,对数据库连接不做释放,接着调用的情况,此时会出现内存增长的情况。可以确定数据库连接不释放,session中结构会不断增长。

            但是至于数据库连接为何释放不了,这个问题,还需要框架部门的同事进一步分析。

            有时候,换个思路,问题也就很容易解释清楚了。

       come on !

  • 相关阅读:
    20165223 week6测试错题总结
    20165223《Java程序设计》第七周Java学习总结
    20165207 第八周学习总结
    2017-2018-2 20165207实验二《Java面向对象程序设计》实验报告
    20165207 第七周学习总结
    20165207 第六周学习总结
    20165207 实验一 Java开发环境的熟悉
    20165207 第五周学习总结
    20165207 第四周学习总结
    20165207 第三周学习总结
  • 原文地址:https://www.cnblogs.com/xumaojun/p/8523350.html
Copyright © 2020-2023  润新知