jmeter内存溢出

当我用jmeter来测试elasticsearch性能的时候,发生过三种性质的内存溢出。

1. index

由于数据流过大,内存使用超过jmeter默认的上限,就溢出了。

用记事本打开jmeter.bat文件,里面修改如下:

set HEAP=-Xms256m -Xmx4g
set NEW=-XX:NewSize=128m -XX:MaxNewSize=1024m
set NEW指的是每个线程占用的内存set HEAP指的是累积线程占用的内存
set PERM=-XX:PermSize=1024m -XX:MaxPermSize=1024m  

2. bulk

由于我当时一次bulk装了1000条请求,而且还有变参是从磁盘文件上获取数据的。这个时候,本地磁盘IOPS过大,成为瓶颈,导致内存持续增大,直至突破上限,内存溢出。

所以我要做的,就是减少IOPS,我就把变参一律改为random生成,不再读磁盘文件,内存达到一个阙值,便不再增长,问题解决。

 

3. 还有一种就是jmeter工具本身对内存的占用。监听器越多,内存开销越大,因为记录数据都暂时放在内存中的。故而如果发现内存消耗持续增长,可查看下开了多少监听器,尤其是结果树、表格查看结果等消耗内存很大。可考虑关闭一些不必要的,我一般仅仅使用summary report和图形结果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值