Jmeter压测实战—Jmeter二次开发之自定义函数

Jmeter是Apache基金会下的一款应用场景非常广的压力测试工具,具备轻量、高扩展性、分布式等特性。Jmeter已支持实现随机数、计数器、时间戳、大小写转换、属性校验等多种函数,方便使用人员使用。如果在使用过程中存在和业务强耦合的常用功能函数,在Jmeter不支持的情况下,那就需要单独开发自定义函数实现特定功能。

本文介绍如何开发Jmeter自定义函数实现快速生成京东宙斯下单标准sign,同时深刻理解Jmeter的插件化机制及高扩展性特性。

1、开发准备

Java基础开发
Maven基本使用
开发依赖版本
JDK 1.8.0Maven 3.6.3Jmeter 5.4.3

2、自定义函数核心实现

2.1 新建项目

pom.xml文件核心配置如下:

新建maven项目,这里项目名为:JSF_Sampler
因为是基于Jmeter的扩展,需要依赖包Jmeter两个核心包,分别是:
ApacheJMeter_core
ApacheJMeter_java
ApacehJMeter_functions
pom.xml文件核心配置如下

  1. <groupId>com.jd.jmeter.jsf</groupId>

  2. <artifactId>JSF_Sampler</artifactId>

  3. <version>1.0-SNAPSHOT</version>

  4. <properties>

  5. <maven.compiler.source>8</maven.compiler.source>

  6. <maven.compiler.target>8</maven.compiler.target>

  7. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

  8. <jmeter-version>5.4.3</jmeter-version>

  9. </properties>

  10. <dependencies>

  11. <dependency>

  12. <groupId>org.apache.jmeter</groupId>

  13. <artifactId>ApacheJMeter_core</artifactId>

  14. <version>${jmeter-version}</version>

  15. </dependency>

  16. <dependency>

  17. <groupId>org.apache.jmeter</groupId>

  18. <artifactId>ApacheJMeter_java</artifactId>

  19. <version>${jmeter-version}</version>

  20. </dependency>

  21. <dependency>

  22. <groupId>org.apache.jmeter</groupId>

  23. <artifactId>ApacheJMeter_functions</artifactId>

  24. <version>${jmeter-version}</version>

  25. </dependency>

  26. </dependencies>

2.2 继承实现AbstractFunction类

实现类依次实现以下几个步骤

1)新建实现类并继承 AbstractFunction

注意:实现类的包名必须包含xxx.functions.xxx,Jmeter使用命名规则实现实现类的加载。

2)重写以下方法,每个方法的用途见下方代码注释

execute()
setParameters()
getReferenceKey()
getArgumentDesc()

  1. /**

  2. * 京东宙斯 下单标准字段常量

  3. */

  4. private static final String APP_KEY = "app_key";

  5. private static final String APP_SECRET = "app_secret";

  6. private static final String ACCESS_TOKEN = "access_token";

  7. private static final String TIMESTAMP = "timestamp";

  8. private static final String V = "v";

  9. private static final String METHOD = "method";

  10. private static final String BUY_PARAM_JSON = "360buy_param_json";

  11. /**

  12. * Jmeter中自定义的函数名,在Jmeter的函数助手中可以看到

  13. */

  14. private static final String FUNC_NAME = "__GenSignFunction";

  15. /**

  16. * 自定义函数的描述,入参,出参,方便使用人员参考使用

  17. */

  18. private static final List<String> desc = new ArrayList<>();

  19. static {

  20. desc.add("This function is used to generate the JD's JOS sign value");

  21. }

  22. /**

  23. * 此为自定义函数核心实现类,其中,入参SampleResult为上次运行的结果,Sampler为当前的采集器;

  24. * 返回值为该函数的返回值

  25. * @param sampleResult

  26. * @param sampler

  27. * @return

  28. * @throws InvalidVariableException

  29. */

  30. @Override

  31. public String execute(SampleResult sampleResult, Sampler sampler) throws InvalidVariableException {

  32. // 入参处理

  33. String param = String.valueOf((CompoundVariable)paramValues[0]);

  34. String signResult = paramHandler(param);

  35. return signResult;

  36. }

  37. /**

  38. * 按京东宙斯sign加密规则生成标准sign

  39. * @param param

  40. * @return

  41. */

  42. public String paramHandler(String param){

  43. Map<String,String> valueMap = new HashMap();

  44. // 按&符号分割

  45. String[] paramArray = param.split("&");

  46. for (int i = 0; i < paramArray.length-1; i++) {

  47. String key = paramArray[i].split("=")[0];

  48. String value = paramArray[i].split("=")[1];

  49. valueMap.put(key,value);

  50. };

  51. // 京东宙斯标准sign

  52. String josGign = EncryptUtil.getSignature(valueMap.get("app_secret")+BUY_PARAM_JSON+valueMap.get("360buy_param_json")

  53. +ACCESS_TOKEN+valueMap.get("access_token")

  54. +APP_KEY+valueMap.get("app_key")

  55. +METHOD+valueMap.get("method")

  56. +TIMESTAMP+valueMap.get("timestamp")

  57. +V+valueMap.get("v")

  58. +valueMap.get("app_secret"));

  59. return josGign;

  60. }

  61. /**

  62. * 配置入参,jmeter函数助手入参

  63. */

  64. @Override

  65. public void setParameters(Collection<CompoundVariable> collection) throws InvalidVariableException {

  66. paramValues = collection.toArray();

  67. }

  68. /**

  69. * 此方法返回自定义的函数名称

  70. */

  71. @Override

  72. public String getReferenceKey() {

  73. return FUNC_NAME;

  74. }

  75. /**

  76. * 此方法返回函数描述信息

  77. */

  78. @Override

  79. public List<String> getArgumentDesc() {

  80. return desc;

  81. }

2.3 最终项目结构

3、Jmeter加载扩展包

以上开发完成,打包此项目,注意这里的打包要包含依赖包。

3.1 maven构建配置

  1. <build>

  2. <finalName>${project.artifactId}</finalName>

  3. <defaultGoal>install</defaultGoal>

  4. <plugins>

  5. <plugin>

  6. <groupId>org.apache.maven.plugins</groupId>

  7. <artifactId>maven-compiler-plugin</artifactId>

  8. <configuration>

  9. <source>1.8</source>

  10. <target>1.8</target>

  11. </configuration>

  12. </plugin>

  13. <plugin>

  14. <groupId>org.apache.maven.plugins</groupId>

  15. <artifactId>maven-assembly-plugin</artifactId>

  16. <configuration>

  17. <descriptorRefs>

  18. <descriptorRef>jar-with-dependencies</descriptorRef>

  19. </descriptorRefs>

  20. </configuration>

  21. <executions>

  22. <execution>

  23. <id>assemble-all</id>

  24. <phase>package</phase>

  25. <goals>

  26. <goal>single</goal>

  27. </goals>

  28. </execution>

  29. </executions>

  30. </plugin>

  31. </plugins>

  32. </build>

3.2 项目打包

打包指令如下

mvn package -Dmaven.test.skip=true

3.3 Jmeter加载扩展包

将打包后的扩展包放置到Jmeter的ext目录:apache-jmeter-5.4.3/lib/ext/

启动Jmeter后,Jmeter会自动加载ext目录中的扩展包

打开Jmeter函数助手后,可以看到本次实现类中打印的相关日志

4、自定义函数调用调试

4.1 打开Jmeter函数助手,选择自定义函数

4.2 京东宙斯接口验证

这里使用京东快递获取预制运单号接口,输入GET请求后,直接点击运行函数【Generate & Copy to clipboard】,出参返回32位sign值。

  1. GET请求入参

  2. method=jingdong.etms.waybillcode.get&app_key=349559FAE87E66826499890862E40A44&access_token=c8c2bdc8d1684630bb771a503d5b5a7fkyzh×tamp=2022-01-28 15:10:00&360buy_param_json={"preNum":"1","customerCode":"10K43816","orderType":"0"}&v=2.0&sign=EBB52C6CEDA34703ADE72D4AA4D8F316&app_secret=29959e4cadc14ff4998d4fc26d1e5063

5、总结

本文通过自定义函数实现了京东宙斯下单标准sign的生成,希望通过本项目大家可以学习到:

  • 如何二次开发Jmeter,实现自己特有的自定义函数。
  • 理解为何官方介绍Jmeter是插件化的,高扩展性特性。
  • 更好的理解Jmeter内部处理机制。

在进行JMeter压测实战时,首先需要启动JMeter服务。在Linux系统中,可以使用命令"./jmeter-server"来启动服务;在Windows系统中,可以使用命令"jmeter-server.bat"来启动服务。然后,可以按照以下步骤进行JMeter压测实战: 1. 编写测试计划:打开JMeter软件,创建一个新的测试计划。在测试计划中,可以设置压测的目标、虚拟用户数量、持续时间等参数。还可以添加各种不同类型的Sampler,如HTTP请求、FTP请求等,来模拟真实场景下的用户行为。 2. 配置线程组:在测试计划中,添加一个线程组。线程组用于模拟并发用户。可以设置线程数、启动延迟、循环次数等参数。通过调整线程组的配置,可以模拟不同的压力情况。 3. 添加Sampler:在线程组下添加不同类型的Sampler。Sampler用于发送各种类型的请求,如HTTP请求、FTP请求等。可以根据实际需求添加相应的Sampler,并设置请求的URL、参数、请求方法等。 4. 添加监听器:在测试计划中添加监听器,用于收集和分析测试结果。常用的监听器有查看结果树、聚合报告、图形结果等。可以根据需要选择相应的监听器,并设置输出的格式和详细度。 5. 配置压测环境:在进行JMeter压测实战之前,需要配置好压测环境。确保目标系统正常运行,并根据需要进行参数调整。 6. 运行压测:完成以上步骤后,可以点击JMeter界面上的运行按钮,开始进行压测。测试过程中,可以实时查看监控数据、请求结果和报告等。 7. 分析测试结果:在压测结束后,可以通过监听器输出的结果进行分析。可以查看请求的响应时间、吞吐量、错误率等指标,以评估系统性能和稳定性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值