美文网首页
Jmeter获取响应结果并保存txt文件+Python读取txt

Jmeter获取响应结果并保存txt文件+Python读取txt

作者: 莫依痕 | 来源:发表于2018-05-16 20:04 被阅读0次

    背景:项目有负载均衡策略功能,需要查看请求分配到主机的情况

    1、可以本地开启服务,设置多个主机进行测试,这里3个主机的比例设置为:1:4:5
    image.png
    2、设置线程个数,数量尽量大点,这样可以比较接近设置的均衡比例
    image.png
    3、请求设置好后,在请求处右键,添加->后置处理器->BeanShell PostProcessor,输入以下内容

    如果引用我这边的代码,需要注意3个地方:
    A、正则表达式匹配规则要改,用的是Pattern类的compile()方法
    B、正则表达式匹配出来的结果,用Matcher类里的group()方法获取需要的内容
    C、文件生成是覆盖还是追加的形式,如果是追加,FileOutputStream(file, true),后面一个参数要写true

    image.png
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
    import java.util.*;
    //JMeter的内置API:prev.getResponseData()获取请求的响应内容
    byte[] responseData = prev.getResponseData(); 
    //定义一个String类型的变量 
    String names = "";
    //定义正则表达式需要匹配的模式
    Pattern pattern = Pattern.compile("test instance([123])");
    Matcher result = pattern.matcher(new String(responseData));
    
    while(result.find()){
    //group(0)表示获取第0组一整个匹配(这里是test instance1,test instance2,test instance3之一),group(1)表示获取第1组一整个匹配(这里是括号里的1,2,3之一),如果还有一个括号,可以通过group(2)匹配
        names += result.group(1)+"\r\n";
    }
    //输入即将生成的文件所在的地址
    private String filePath = "E:/application20160314/apache-jmeter-3.2/exportResult/exportFile.txt";  
    BufferedOutputStream bos = null;
    FileOutputStream fos = null;
    File file = null;
    try {
       File file = new File(filePath);
       #创建一个向指定 File 对象表示的文件中写入数据的文件输出流。如果第二个参数为 true,则将字节写入文件末尾处,而不是写入文件开始处。
       fos = new FileOutputStream(file, true); 
       bos = new BufferedOutputStream(fos);
       bos.write(names.getBytes());
    } catch (Exception e) {
       e.printStackTrace();
    } finally {
       if (bos != null) {
          try {
             bos.close();
          } catch (IOException e1) {
             e1.printStackTrace();
          }
       }
       if (fos != null) {
          try {
             fos.close();
          } catch (IOException e1) {
             e1.printStackTrace();
          }
       }
    }
    
    4、“exportFile.txt”会在设置的路径“E:\application20160314\apache-jmeter-3.2\exportResult”下自动创建出来
    image.png
    image.png
    5、通过Python处理Jmeter生成的exportFile.txt文件

    A、可以通过type()len()方法查看返回数值的类型和长度
    B、我这里的文件是一行显示一个,取值的时候,会获取到换行,要用strip(),此方法用于移除字符串头尾指定的字符(默认为空格),否则在判断字符是否相等的时候,返回的结果会一直是false。

    # coding=utf-8
    import sys
    import types
    f = open(r"E:\\application20160314\\apache-jmeter-3.2\\exportResult\\exportFile.txt","r")
    lines = f.readlines()
    i1 = 0
    i2 = 0
    i3 = 0
    for line in lines:
        # 查看line返回的类型和长度
        print(type(line),len(line))
        # strip()方法是去掉首尾空格
        line = line.strip()
        if line=="1":
            i1 = i1 + 1
        if line == "2":
            i2 = i2 + 1
        if line == "3":
            i3 = i3 + 1
    print(i1)
    print(i2)
    print(i3)
    
    6、查看结果,可以看出第一个主机收到106个请求,第二个主机收到404个请求,第三个主机收到490个请求。和负载均衡中设置的轮循策略,以及负载权重比例接近1:4:5的结果。
    image.png

    相关文章

      网友评论

          本文标题:Jmeter获取响应结果并保存txt文件+Python读取txt

          本文链接:https://www.haomeiwen.com/subject/rojmdftx.html