当前位置: 首页 > news >正文

【测试工具】通过Jmeter压测存储过程

目录

    • 一、存储过程准备
      • 1.1、 建立空表
      • 1.2、 建立存储过程
      • 1.3、调试
    • 二、测试工具准备
    • 三、工具配置及执行
      • 3.1、配置JDBC Connection Configuration:
      • 3.2、配置吞吐量控制器
      • 3.3、配置JDBC Request

一、存储过程准备

1.1、 建立空表

CREATE TABLE test_data ( id NUMBER, name VARCHAR2(50), age NUMBER );

1.2、 建立存储过程

CREATE OR REPLACE PROCEDURE insert_test_data
(n IN NUMBER) AS
BEGIN--EXECUTE IMMEDIATE 'truncate table test_data';FOR i IN 1..n LOOPINSERT INTO test_data VALUES (i, 'Name' || i, i * 10);END LOOP;
COMMIT;
END insert_test_data;

1.3、调试

select count(*) from test_data t; call insert_test_data(1000); truncate table test_data;

二、测试工具准备

1、网上找到:mysql-connector-java-8.0.29.jar(版本不限定),放到Jmeter目录\lib\ext下。
2、网上找或将本地:ojdbc14.jar,放到Jmeter目录\lib下。

三、工具配置及执行

全局配置如下图:

在这里插入图片描述

3.1、配置JDBC Connection Configuration:

右键,Config Element下添加节点,配置如图:
在这里插入图片描述

a. Name可以随意改,改后保存生效
b. Variable Name for created pool,随便起一个,不过需要跟后续步骤的配置一致,建议就叫oracle
c. 中间一大段暂时默认,Validation Query随意选一个
d. Database URL: jdbc:oracle:thin:@{ip}/{oracle服务名},其中{ip}是数据库服务器ip,{oracle服务名}是TNS中 的Service_Name,类似orcl这种
e. 连接数据库的用户名和密码

3.2、配置吞吐量控制器

在这里插入图片描述

如图就是占20%的吞吐量。示例中SP占20%,SQL占80%。模拟实际的80%查询,20%写入的场景。

3.3、配置JDBC Request

右键,Sampler里找到JDBC Request,添加。
对于存储过程:
在这里插入图片描述

a. Variable Name of Pool…:和JDBC Connection Configuration配置一致,这里配为:oracle
b. Query Type: 存储过程的话,选Callable Statement
c. Query: 如图,写存储过程调用,照图上格式写,参数用?表示,多个参数用逗号隔开
d. Para Values,参数值,多个用逗号隔开
e. Para types, 参数的数据类型
f. Variable names,返回值列名
g. HandleResutleSet:Store as String即可

对于SQL语句:
在这里插入图片描述

Query Type选Select Statement,Query中直接写SQL语句即可。注意语句最后不要写“;”

其他配置如查询结果树,聚合报告,TPS,PerfMon监控等,同基础Jmeter配置


http://www.mrgr.cn/news/62901.html

相关文章:

  • sql模糊关联匹配
  • FPGA 21 ,深入理解 Verilog 中的基数,以及二进制数与十进制数之间的关系( Verilog中的基数 )
  • 服务器引导异常,Grub报错: error: ../../grub-core/fs/fshelp.c:258:file xxxx.img not found.
  • HTTP常见状态码:从1xx到 5xx的全面解析
  • Linux物理地址到虚拟地址的映射
  • Windows 10 ARM工控主板连接I2S音频芯片
  • Git学习记录
  • 14. 不修改数组找出重复的数字
  • 【论文速读】Optimization-based Prompt Injection Attack to LLM-as-a-Judge
  • Python 从入门到实战43(Pandas数据结构)
  • 哈希函数简介
  • 【调试记录】CARLA车辆actor设置BehaviorAgent自动规划后不沿道路行驶
  • Terraform Provider 加速方案
  • 什么是 Spring Cloud Bus?我们需要它吗?
  • 【AI日记】24.10.31 学习LangChain和寻找AI研究报告(比如麦肯锡)
  • ROS(快速初步入门)
  • 谷歌Google搜索广告账户代理开户!
  • iDP3复现代码运行逻辑全流程(一)——部署全流程代码逻辑梳理(Learning)
  • python opencv1
  • 金蝶云苍穹的Extension与Nop平台的Delta的区别
  • 基于LORA的一主多从监测系统_4G模块上巴法云
  • Linux高阶——1027—进程间关系相关
  • SpringFactoriesLoader
  • Java项目实战II基于Java+Spring Boot+MySQL的编程训练系统(源码+数据库+文档)
  • VB中如何处理国际化(Internationalization)和本地化(Localization)
  • 低代码的崛起:改变开发的游戏规则