现象案例记录:
测试环境:2台应用服务器,2台数据库服务器
测试执行策略:1000线程持续请求10分钟
压力测试中,发现在稳定的tps请求下,应用服务器内存持续消耗上升(内存泄漏一般情况下发生在应用服务器中),当测试停止之后,内存消耗在最终点无法恢复,只有重启应用服务器后恢复
知识科普
以发生的方式来分类,内存泄漏可以分为4类:
1. 常发性内存泄漏。发生内存泄漏的代码会被多次执行到,每次被执行的时候都会导致一块内存泄漏。
2. 偶发性内存泄漏。发生内存泄漏的代码只有在某些特定环境或操作过程下才会发生。常发性和偶发性是相对的。对于特定的环境,偶发性的也许就变成了常发性的。所以测试环境和测试方法对检测内存泄漏至关重要。
3. 一次性内存泄漏。发生内存泄漏的代码只会被执行一次,或者由于算法上的缺陷,导致总会有一块仅且一块内存发生泄漏。比如,在类的构造函数中分配内存,在析构函数中却没有释放该内存,所以内存泄漏只会发生一次。
4. 隐式内存泄漏。程序在运行过程中不停的分配内存,但是直到结束的时候才释放内存。严格的说这里并没有发生内存泄漏,因为最终程序释放了所有申请的内存。但是对于一个服务器程序,需要运行几天,几周甚至几个月,不及时释放内存也可能导致最终耗尽系统的所有内存。所以,我们称这类内存泄漏为隐式内存泄漏。
监控指标:
Memory/ Available Bytes 是指剩余的可用物理内存,单位是兆字节(参考值:>=10%)。表明进程当前可使用的内存字节数。
Memory/ Pages/sec 是表明由于硬件页面错误而从磁盘取出的页面数,或由于页面错误而写入磁盘以释放工作集空间的页面数。
Process/Private Bytes 是指当前进程中运行的私有内存,如果此内存不断攀升,表示当前存在的内存泄漏,一般情况如果资源合理利用的话,该指标值波动比较平稳。
问题分析案例
网友评论