• 【转】JMeter入门


    一、JMeter概述
      JMeter就是一个测试工具,相比于LoadRunner等测试工具,此工具免费,且比较好用,但是前提当然是安装Java环境;
      JMeter可以做
      (2)数据库测试;
      (3)Java程序的测试;
      (4)HTTP及FTP测试;
      (5)Web Service测试;
      等等;
      和JMeter一起使用的可能是JDK自带的测试工具JConsole,位于JDKinJConsole,此工具主要观察堆、JVM、CPU的使用情况,界面如下:
      二、JMeter安装
      解压缩即可;
      JMeter插件:http://code.google.com/p/jmeter-plugins/downloads/detail?name=JMeterPlugins-0.5.3.zip
      下载后将jar文件放到JMETER_HOMElibext目录;
     
    三、JMeter常用组件
      测试计划:整个测试计划;
      线程组:所有的任务都是基于线程组,开通多少个线程就代表有多少个并发用户;
      Ramp-Up Period:在这么多时间内完成全部测试,比如开了2个线程,而Ramp-Up Period为3,则每个线程的间隔为1.5秒;
      Sampler:所有的测试任务都是Sampler,即任何测试任务的类别都是Sampler,比如HTTP请求、JDBC请求、FTP请求;
      断言:对Sampler的测试进行判断是否正确;
      监听器:对Sampler的请求结果进行统计、显示;
      常用的层次结构为:
      常用的组件有:
      HTTP请求:模拟HTTP请求;
      查看结果树:对于每个请求,可以查看HTTP请求和HTTP响应;
      图形结果:可以图形显示吞吐量、响应时间等;
      聚合报告:总体的吞吐量、响应时间;
      1、Label: 定义的HTTP请求名称
      2、Samples: 表示这次测试中一共发出了多少个请求
      3、Average: 访问页面的平均响应时间
      4、Min: 访问页面的最小响应时间
      5、Max: 访问页面的最大响应时间
      6、Error%: 错误的请求的数量/请求的总数
      7、Throughput:每秒完成的请求数
      8、KB/Sec: 每秒从服务器端接收到的数据量
    场景描述:
      自己建立一个服务器端,接受参数:name和age,并将这些数据保存到数据库中;
      http://localhost:8080/Server/SaveServlet?name=xxx&age=xxx
      我们通过JMeter对其进行压力测试
      目标:开1000个线程,每个线程循环1次,全部操作在3秒内完成;
      结构如下:
    结果如下:
    一般自己手动的设置JMeter会比较麻烦,如果一边操作页面,提交表单,一边能够自动生成JMeter的脚本,则非常方便;
      BadBoy:录制JMeter脚本;
      Donwload URL:http://www.badboy.com.au/download/add
      BadBoy界面如下:
      我们可以在地址输入栏中输入你要访问的页面,比如www.baidu.com,然后查询xiazdong后,点击:停止录制;
      然后点击"File --> Export to JMeter"即可生成JMeter脚本;
      打开后生成如下结构:
     
     
     
     
    我们只需要运行即可模拟刚才查询"xiazdong"的过程,当然我们可以同时开启1000个线程模拟1000个用户在查询xiazdong;
      图形结果效果如下:
    目的:对Java程序进行测试
      一、核心步骤
      1.创建一个Java工程;
      2.将JMeter的lib目录下的jar文件添加进此工程的Build Path;
      3.创建一个类并实现JavaSamplerClient接口或继承AbstractJavaSamplerClient,并重写:
    public Arguments getDefaultParameters():设置可用参数及的默认值;
    public void setupTest(JavaSamplerContext arg0):每个线程测试前执行一次,做一些初始化工作
    public SampleResult runTest(JavaSamplerContext arg0):开始测试,从arg0参数可以获得参数值;
    public void teardownTest(JavaSamplerContext arg0):测试结束时调用;
    4.Export为Runnable Jar File;
      5.将此jar包放入JMETER_HOMElibext目录;
      6.以管理员身份打开JMeter;
      7.创建线程组、Java Request、结果树,进行测试;
      二、实例
      利用JMeter对服务进行性能测试,服务为:将输入的两个参数通过IO存入文件;
      1、编写Java代码
      服务:
    package test;
    import java.io.File;
    import java.io.PrintWriter;
    public class OutputService {
    public static void output(String filename,int a, int b) throws Exception {
    PrintWriter out = new PrintWriter(new File(filename));
    out.write(a+":"+b);
    out.close();
    }
    }
      测试类:
    package test;
    import org.apache.jmeter.config.Arguments;
    import org.apache.jmeter.protocol.java.sampler.JavaSamplerClient;
    import org.apache.jmeter.protocol.java.sampler.JavaSamplerContext;
    import org.apache.jmeter.samplers.SampleResult;
    public class PerformenceTest implements JavaSamplerClient {
    private SampleResult results;
    private String a;
    private String b;
    private String filename;
    // 设置传入的参数,可以设置多个,已设置的参数会显示到Jmeter的参数列表中
    public Arguments getDefaultParameters() {
    Arguments params = new Arguments();
    params.addArgument("filename", "0");//设置参数,并赋予默认值0
    params.addArgument("a", "0");//设置参数,并赋予默认值0
    params.addArgument("b", "0");//设置参数,并赋予默认值0
    return params;
    }
    // 初始化方法,实际运行时每个线程仅执行一次,在测试方法运行前执行
    public void setupTest(JavaSamplerContext arg0) {
    results = new SampleResult();
    }
    // 测试执行的循环体,根据线程数和循环次数的不同可执行多次
    @Override
    public SampleResult runTest(JavaSamplerContext arg0) {
    b = arg0.getParameter("b"); // 获取在Jmeter中设置的参数值
    a = arg0.getParameter("a"); // 获取在Jmeter中设置的参数值
    filename = arg0.getParameter("filename"); // 获取在Jmeter中设置的参数值
    results.sampleStart();// jmeter 开始统计响应时间标记
    try {
    OutputService test = new OutputService();
    test.output(filename,Integer.parseInt(a), Integer.parseInt(b));
    results.setSuccessful(true);
    // 被测对象调用
    } catch (Throwable e) {
    results.setSuccessful(false);
    e.printStackTrace();
    } finally {
    results.sampleEnd();// jmeter 结束统计响应时间标记
    }
    return results;
    }
    // 结束方法,实际运行时每个线程仅执行一次,在测试方法运行结束后执行
    public void teardownTest(JavaSamplerContext arg0) {
    }
    public static void main(String[] args) {
    // TODO Auto-generated method stub
    Arguments params = new Arguments();
    params.addArgument("a", "0");//设置参数,并赋予默认值0
    params.addArgument("b", "0");//设置参数,并赋予默认值0
    JavaSamplerContext arg0 = new JavaSamplerContext(params);
    PerformenceTest test = new PerformenceTest();
    test.setupTest(arg0);
    test.runTest(arg0);
    test.teardownTest(arg0);
    }
    }
    Export 为 Runnable Jar File;
     
     
     
     
     
    2、设置JMeter
      以管理员身份打开JMeter,并创建Java Request后,结构如下图所示:
      在Java请求中发现了自己新建的测试类:
      我们在JMeter中发现参数有三个:
      我们在响应的数值中填入:
      大家一定很奇怪,怎么会有一些看不懂的东西,这是JMeter提供的函数,我们可以在
      因为我们要做的是性能测试,因此我们需要开多个线程并发测试,因此随机数很重要;
      常用的函数为:
      (1)_Random生成随机整数;
      (2)_RandomString生成随机字符串;
      在线程组中设置并发线程数为10000,保存后即可运行;
      图形结果如下所示:
     
     
    聚合报告:
      表格查看结果:
      结果成功,成功生成了接近10000个文件:
      3.期间遇到的问题
      3.1 Export为Jar File导致Java Request的类名称无法找到;
      3.2 JMeter java.lang.OutOfMemoryError: PermGen space问题:
      在JMeter.bat 中修改:
      set HEAP=-Xms512m -Xmx1024m
      set NEW=-XX:NewSize=128m -XX:MaxNewSize=128m
      set SURVIVOR=-XX:SurvivorRatio=8 -XX:TargetSurvivorRatio=50%
      set TENURING=-XX:MaxTenuringThreshold=2
      set RMIGC=-Dsun.rmi.dgc.client.gcInterval=600000 -Dsun.rmi.dgc.server.gcInterval=600000
      set PERM=-XX:PermSize=256m -XX:MaxPermSize=512m
      3.3 JMeter需要以管理员身份打开,否则会出现:
     
     
     
     
     
  • 相关阅读:
    bzoj 3527: [Zjoi2014]力
    bzoj 1797: [Ahoi2009]Mincut 最小割
    bzoj 1028: [JSOI2007]麻将
    bzoj 1019: [SHOI2008]汉诺塔
    bzoj 1023: [SHOI2008]cactus仙人掌图
    bzoj 3289: Mato的文件管理
    bzoj 4034: [HAOI2015]T2
    bzoj 1218: [HNOI2003]激光炸弹
    bzoj 2431: [HAOI2009]逆序对数列
    The full stack trace of the root cause is available in the Apache Tomcat/8.0.8 logs.
  • 原文地址:https://www.cnblogs.com/blongfree/p/4980945.html
Copyright © 2020-2023  润新知