qileilove

          blog已經(jīng)轉(zhuǎn)移至github,大家請(qǐng)?jiān)L問 http://qaseven.github.io/

          JMeter入門(4):Java Request實(shí)例

           目的:對(duì)Java程序進(jìn)行測(cè)試;
            一、核心步驟
            1.創(chuàng)建一個(gè)Java工程;
            2.將JMeter的lib目錄下的jar文件添加進(jìn)此工程的Build Path;
            3.創(chuàng)建一個(gè)類并實(shí)現(xiàn)JavaSamplerClient接口或繼承AbstractJavaSamplerClient,并重寫:
          public Arguments getDefaultParameters():設(shè)置可用參數(shù)及的默認(rèn)值;
          public void setupTest(JavaSamplerContext arg0):每個(gè)線程測(cè)試前執(zhí)行一次,做一些初始化工作;
          public SampleResult runTest(JavaSamplerContext arg0):開始測(cè)試,從arg0參數(shù)可以獲得參數(shù)值;
          public void teardownTest(JavaSamplerContext arg0):測(cè)試結(jié)束時(shí)調(diào)用;
          4.Export為Runnable Jar File;
            5.將此jar包放入JMETER_HOME\lib\ext目錄;
            6.以管理員身份打開JMeter;
            7.創(chuàng)建線程組、Java Request、結(jié)果樹,進(jìn)行測(cè)試;
            二、實(shí)例
            利用JMeter對(duì)服務(wù)進(jìn)行性能測(cè)試,服務(wù)為:將輸入的兩個(gè)參數(shù)通過IO存入文件;
            1、編寫Java代碼
            服務(wù):
          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();
          }
          }
            測(cè)試類:
          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;
          // 設(shè)置傳入的參數(shù),可以設(shè)置多個(gè),已設(shè)置的參數(shù)會(huì)顯示到Jmeter的參數(shù)列表中
          public Arguments getDefaultParameters() {
          Arguments params = new Arguments();
          params.addArgument("filename", "0");//設(shè)置參數(shù),并賦予默認(rèn)值0
          params.addArgument("a", "0");//設(shè)置參數(shù),并賦予默認(rèn)值0
          params.addArgument("b", "0");//設(shè)置參數(shù),并賦予默認(rèn)值0
          return params;
          }
          // 初始化方法,實(shí)際運(yùn)行時(shí)每個(gè)線程僅執(zhí)行一次,在測(cè)試方法運(yùn)行前執(zhí)行
          public void setupTest(JavaSamplerContext arg0) {
          results = new SampleResult();
          }
          // 測(cè)試執(zhí)行的循環(huán)體,根據(jù)線程數(shù)和循環(huán)次數(shù)的不同可執(zhí)行多次
          @Override
          public SampleResult runTest(JavaSamplerContext arg0) {
          b = arg0.getParameter("b"); // 獲取在Jmeter中設(shè)置的參數(shù)值
          a = arg0.getParameter("a"); // 獲取在Jmeter中設(shè)置的參數(shù)值
          filename = arg0.getParameter("filename"); // 獲取在Jmeter中設(shè)置的參數(shù)值
          results.sampleStart();// jmeter 開始統(tǒng)計(jì)響應(yīng)時(shí)間標(biāo)記
          try {
          OutputService test = new OutputService();
          test.output(filename,Integer.parseInt(a), Integer.parseInt(b));
          results.setSuccessful(true);
          // 被測(cè)對(duì)象調(diào)用
          } catch (Throwable e) {
          results.setSuccessful(false);
          e.printStackTrace();
          } finally {
          results.sampleEnd();// jmeter 結(jié)束統(tǒng)計(jì)響應(yīng)時(shí)間標(biāo)記
          }
          return results;
          }
          // 結(jié)束方法,實(shí)際運(yùn)行時(shí)每個(gè)線程僅執(zhí)行一次,在測(cè)試方法運(yùn)行結(jié)束后執(zhí)行
          public void teardownTest(JavaSamplerContext arg0) {
          }
          public static void main(String[] args) {
          // TODO Auto-generated method stub
          Arguments params = new Arguments();
          params.addArgument("a", "0");//設(shè)置參數(shù),并賦予默認(rèn)值0
          params.addArgument("b", "0");//設(shè)置參數(shù),并賦予默認(rèn)值0
          JavaSamplerContext arg0 = new JavaSamplerContext(params);
          PerformenceTest test = new PerformenceTest();
          test.setupTest(arg0);
          test.runTest(arg0);
          test.teardownTest(arg0);
          }
          }
          Export 為 Runnable Jar File;

          2、設(shè)置JMeter
            以管理員身份打開JMeter,并創(chuàng)建Java Request后,結(jié)構(gòu)如下圖所示:
            在Java請(qǐng)求中發(fā)現(xiàn)了自己新建的測(cè)試類:
            我們?cè)贘Meter中發(fā)現(xiàn)參數(shù)有三個(gè):
            我們?cè)陧憫?yīng)的數(shù)值中填入:
            大家一定很奇怪,怎么會(huì)有一些看不懂的東西,這是JMeter提供的函數(shù),我們可以在
            因?yàn)槲覀円龅氖切阅軠y(cè)試,因此我們需要開多個(gè)線程并發(fā)測(cè)試,因此隨機(jī)數(shù)很重要;
            常用的函數(shù)為:
            (1)_Random生成隨機(jī)整數(shù);
            (2)_RandomString生成隨機(jī)字符串;
            在線程組中設(shè)置并發(fā)線程數(shù)為10000,保存后即可運(yùn)行;
            圖形結(jié)果如下所示:
          聚合報(bào)告:
            表格查看結(jié)果:
            結(jié)果成功,成功生成了接近10000個(gè)文件:
            3.期間遇到的問題
            3.1 Export為Jar File導(dǎo)致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需要以管理員身份打開,否則會(huì)出現(xiàn):
          相關(guān)文章:

          posted on 2013-11-19 11:09 順其自然EVO 閱讀(452) 評(píng)論(0)  編輯  收藏 所屬分類: jmeter and badboy

          <2013年11月>
          272829303112
          3456789
          10111213141516
          17181920212223
          24252627282930
          1234567

          導(dǎo)航

          統(tǒng)計(jì)

          常用鏈接

          留言簿(55)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 杭锦后旗| 襄城县| 盐边县| 肥西县| 资源县| 赣榆县| 阳原县| 武城县| 石屏县| 永济市| 池州市| 昆山市| 连南| 盐山县| 太仆寺旗| 安平县| 河津市| 左贡县| 五指山市| 兴山县| 新巴尔虎左旗| 卢氏县| 江安县| 静安区| 通榆县| 剑川县| 辉南县| 工布江达县| 招远市| 奉贤区| 云龙县| 兴隆县| 崇义县| 榆林市| 福安市| 涪陵区| 德阳市| 达州市| 惠州市| 盐边县| 禄丰县|