Python + Jmeter 实现自动化性能压测

本文详细描述了如何通过Python脚本利用gRPC调用C++底层接口进行数据库操作,包括插入和查询,以及与JMeter集成进行并发压力测试的过程。脚本成功执行3次操作后,JMeter验证返回结果并记录执行状态。
摘要由CSDN通过智能技术生成

Step01: Python脚本开发

文件路径:D://wl//testproject//Fone-grpc//project1//test_client.py

Python 脚本作用:

1.通过 grpc 调用底层 c++ 的接口,做数据库的数据插入与查询操作,然后将返回的结果进行拼接与输出。

2.代码里面将每一次调用后返回的内容进行拼接后,并做了成功信息的统计,输出成功的次数为3,输出后会转给 jmeter 里面的脚本获取。

  1. from __future__ import print_function

  2. import logging

  3. import sys

  4. import grpc

  5. import Storage_pb2 # Storage_pb2.py which contains our generated request and response classes

  6. import StorageService_pb2_grpc # StorageService_pb2_grpc.py which contains our generated client and server classes.

  7. host="10.10.1.117:50066"

  8. def run():

  9. result=""

  10. with grpc.insecure_channel(host) as channel:

  11. resp0=StorageService_pb2_grpc.FOneStorageStub(channel).InsertKVS(Storage_pb2.PUpsertKVS(

  12. DBName="MergeLog",TableName="MergeLog",KeyValues=[{"Key":b'',"Key":b''}],Upsert=True,Transaction=True

  13. ))

  14. result+=str(resp0)

  15. with grpc.insecure_channel(host) as channel:

  16. stud1=StorageService_pb2_grpc.FOneStorageStub(channel)

  17. resp1=stud1.InsertV(Storage_pb2.PInsertV(DBName="MergeLog", TableName="MergeLog", Value=b"1"))

  18. result += str(resp1)

  19. with grpc.insecure_channel(host) as channel:

  20. stud2=StorageService_pb2_grpc.FOneStorageStub(channel)

  21. resp2=stud2.FindOne(Storage_pb2.PFindK(DBName="MergeLog", TableName="MergeLog", Key="1"))

  22. result += str(resp2)

  23. result=result.replace("\n", " ")

  24. result=result.count("Successful return: 0")

  25. print(result)

  26. if __name__ == '__main__':

  27. logging.basicConfig()

  28. run()

PS:在本地调试好脚本,确保符合预期。

Step02: Jmeter 创建 beanshell 取样器

脚本内容如下:

  1. import java.io.BufferedReader;

  2. import java.io.InputStreamReader;

  3. log.info("----------------------------start to exe");

  4. String command = "cmd /c python D://wl//testproject//Fone-grpc//project1//test_client.py"; //定义要执行的python文件路径

  5. String var;

  6. Runtime rt = Runtime.getRuntime();

  7. Process pr = rt.exec(command); //执行上面的python脚本

  8. pr.waitFor()

  9. BufferedReader b = new BufferedReader(new InputStreamReader(pr.getInputStream())); // 转换执行脚本后的返回响应

  10. String line = "";

  11. StringBuilder response = new StringBuilder();

  12. while ((line = b.readLine()) != null) {

  13. response.append(line);

  14. }

  15. String response_data = response.toString();

  16. log.info(response_data);

  17. if(response_data.equals("3")){ // 判断响应的内容是否有3次,如果不是3次就表示执行失败了

  18. log.info("---------------------------success end exe");

  19. }else{

  20. log.error("--------------------------failed end exe"); //这里的输出一次会记录一次失败次数

  21. }

  22. b.close();

Step03: 执行效果

通过 jmeter 工具进行并发操作,对后端底层接口进行压力测试,效果不错,效果图如下所示。

图片

Step04: Jmeter日志输出

  1. 2023-02-22 17:26:08,539 INFO o.a.j.t.JMeterThread: Stopping because end time detected by thread: 线程组--python 1-33

  2. 2023-02-22 17:26:08,539 INFO o.a.j.t.JMeterThread: Thread finished: 线程组--python 1-33

  3. 2023-02-22 17:26:08,597 INFO o.a.j.u.BeanShellTestElement: 3

  4. 2023-02-22 17:26:08,597 INFO o.a.j.u.BeanShellTestElement: ---------------------------success end exe

  5. 2023-02-22 17:26:08,598 INFO o.a.j.t.JMeterThread: Stopping because end time detected by thread: 线程组--python 1-82

  6. 2023-02-22 17:26:08,598 INFO o.a.j.t.JMeterThread: Thread finished: 线程组--python 1-82

  7. 2023-02-22 17:26:08,608 INFO o.a.j.u.BeanShellTestElement: 2

  8. 2023-02-22 17:26:08,608 ERROR o.a.j.u.BeanShellTestElement: --------------------------failed end exe

如果今天的分享对你有帮助的话,请毫不犹豫:关注、分享、点赞、在看、收藏呀~

 

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

  • 14
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值