python保存结果到txt_Jmeter获取响应结果并保存txt文件+Python读取txt文件并处理响应结果...

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

1、可以本地开启服务,设置多个主机进行测试,这里3个主机的比例设置为:1:4:5

4b0406795023?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

2、设置线程个数,数量尽量大点,这样可以比较接近设置的均衡比例

4b0406795023?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

3、请求设置好后,在请求处右键,添加->后置处理器->BeanShell PostProcessor,输入以下内容

如果引用我这边的代码,需要注意3个地方:

A、正则表达式匹配规则要改,用的是Pattern类的compile()方法

B、正则表达式匹配出来的结果,用Matcher类里的group()方法获取需要的内容

C、文件生成是覆盖还是追加的形式,如果是追加,FileOutputStream(file, true),后面一个参数要写true

4b0406795023?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

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”下自动创建出来

4b0406795023?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

4b0406795023?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

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的结果。

4b0406795023?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值