• jmeter 内存溢出原因及解决方法


    jmeter是一个java开发的开源性能测试工具,在性能测试中可支持模拟并发压测,但有时候当模拟并发请求较大或者脚本运行时间较长时,压力机会出现卡顿甚至报异常————内存溢出,

    这里就介绍下如何解决内存溢出及相关的知识点。。。

    首先来看看我们常说的内存泄漏、内存溢出是什么?

    内存泄露是指你的应用使用资源之后没有及时释放,导致应用内存中持有了不需要的资源,这是一种状态描述;

    内存溢出是指你应用的内存已经不能满足正常使用了,堆栈已经达到系统设置的最大值,进而导致崩溃,这事一种结果描述;

    通常都是由于内存泄露导致堆栈内存不断增大,从而引发内存溢出。

    在利用jmeter测试过程中,如果内存溢出的话,一般会出现这个提示:java.lang.OutOfMemoryError: Java heap space:意思就是堆内存溢出,不够用了。

    说到堆栈内存,顺带简单介绍下堆栈的相关知识

    内存溢出解决方法:调整堆内存大小

    步骤:

    1、打开jmeter安装文件(可以用notepad++打开),bin目录下的jmeter.bat文件:

     

    2、找到set HEAP开头的内容,根据具体需要修改堆(heap)值大小,以及NEW分配的内存值大小:

     

    这里默认值为:

    set HEAP=-Xms512m -Xmx512m
    set NEW=-XX:NewSize=256m -XX:MaxNewSize=256m

    将其修改为:

    set HEAP=-Xms512m -Xmx4096m
    set NEW=-XX:NewSize=256m -XX:MaxNewSize=512m

    注意:一般而言,堆的最大值不要超过物理内存的一半,否则容易导致jmeter运行变慢、卡顿甚至内存溢出(因为java本身的垃圾回收机制是动态分配内存,

    调整时候其本身会占用很多内存),NEW分配的内存,不宜太大!

    3、修改完成后,关闭文件,重启jmeter既可以:

    PS:当需要模拟的线程数较大时,就需要根据具体情况采用分布式压测的方式了,这种修改堆大小的方法只适用一部分情况,并不是万能的!

    ————我们之所以要努力,不是为了改变世界,而是为了不让世界改变我们。无论你是谁,无论你正在经历什么,坚持住,你定会看见最坚强的自己。
  • 相关阅读:
    scrapy中selenium的应用
    Django的锁和事务
    redis
    【leetcode】187. Repeated DNA Sequences
    【leetcode】688. Knight Probability in Chessboard
    【leetcode】576. Out of Boundary Paths
    【leetcode】947. Most Stones Removed with Same Row or Column
    【leetcode】948. Bag of Tokens
    【leetcode】946. Validate Stack Sequences
    【leetcode】945. Minimum Increment to Make Array Unique
  • 原文地址:https://www.cnblogs.com/longshao1239/p/12049701.html
Copyright © 2020-2023  润新知