zoukankan      html  css  js  c++  java
  • Jmeter性能测试(三、常见错误)

    5.性能测试常见错误
    1)java.net.SocketException: Socket closed

    解决方法:
    该问题可以尝试通过以下方法解决。
    如果在 HTTP Request Sampler 的 Basic 里勾选了Use KeepAlive,那么建议在 Advanced 页签下:
    (1)Implementation 选为 HttpClient4
    (2)Timeouts 中的 Connect 一般设置一个10~60秒的值,表示连接的空闲超时时间,避免由于没收到被压测端的响应回来的 Keep-Alive 的 Header 导致的连接断开
    这个值的单位是毫秒:15s*1000=15000s

    通过上述方法设置后,再次压测,还是会出现这个错误

    2)java.lang.OutOfMemoryError

    (1)问题原因:
    用JMeter压测,有时候当模拟并发请求较大或者脚本运行时间较长时,JMeter会停止,报OOM(内存溢出)错误。
    原因是JMeter是一个纯Java开发的工具,内存由java虚拟机JVM管理,当内存回收不及时,堆内存不足时,就会报内存溢错误。
    概念补充:
    内存泄露:应用使用资源之后没有及时释放,导致应用内存中持有了不需要的资源。
    内存溢出:应用的内存已经不能满足正常使用了,堆栈已经达到系统设置的最大值,进而导致崩溃。
    通常都是由于内存泄露导致堆栈内存不断增大,从而引发内存溢出。
    对JMeter而言也是如此,JMeter测试过程中,如果内存溢出的话,一般会出现上图中的提示:java.lang.OutOfMemoryError: Java heap space:意思就是堆内存溢出,不够用了
    (2)解决方法
    知道了报错出现的原因是因为堆内存大小不足引起的,自然而然就会想到内存溢出的解决方法:调整堆内存大小。
    步骤(以Windows系统为例,Linux系统类似):
    ①打开jmeter.bat文件,按关键字“HEAP”搜索,把原来的配置改为如下:
    修改前:
    if not defined HEAP (
    rem See the unix startup file for the rationale of the following parameters,
    rem including some tuning recommendations
    set HEAP=-Xms1g -Xmx1g -XX:MaxMetaspaceSize=256m
    )
    修改后:

    if not defined HEAP (
    rem See the unix startup file for the rationale of the following parameters,
    rem including some tuning recommendations
    set HEAP=-Xms512m -Xmx4000m
    set NEW=-XX:NewSize=256m -XX:MaxNewSize=512m
    )

    set HEAP=-Xms512m -Xmx4000m:调整堆内存的大小
    set NEW=-XX:NewSize=256m -XX:MaxNewSize=512m:调整堆内存中新生带的大小
    注意:
    这个值不是越大越好,要根据压测使用的机器而定,一般而言,堆内存的最大值不要超过物理内存的一半,否则容易导致jmeter运行变慢、
    卡顿甚至内存溢出(因为java本身的垃圾回收机制是动态分配内存,调整的时候其本身会占用很多内存),NEW分配的内存,不宜太大。
    ②修改完成后保存,重启JMeter,即可生效。

  • 相关阅读:
    webStorage和cookie相比存在的优势
    session、localStorage和cookie之间的区别
    了解常见的状态码
    什么情况下会碰到跨域问题?有哪些方法可以解决
    什么是跨域?跨域请求资源的方式有哪些?
    垃圾回收机制
    400,500错误
    Junit添加完maven依赖无法使用@Test
    Maven资源过滤问题处理
    javascript的一些注意点
  • 原文地址:https://www.cnblogs.com/bdzxh/p/14043714.html
Copyright © 2011-2022 走看看