51Testing软件测试论坛

标题: Jmeter压测存储过程来看这篇 [打印本页]

作者: 梦幻小丑灯    时间: 2023-8-11 10:53
标题: Jmeter压测存储过程来看这篇
一、存储过程准备:
1、建立一个空表:
  1. <font size="3">CREATE TABLE test_data ( id NUMBER, name VARCHAR2(50), age NUMBER );
  2. </font>
复制代码
2、建立一个存储过程:
  1. <font size="3">CREATE OR REPLACE PROCEDURE insert_test_data
  2. (n IN NUMBER) AS
  3. BEGIN
  4.   --EXECUTE IMMEDIATE 'truncate table test_data';
  5.   FOR i IN 1..n LOOP
  6.     INSERT INTO test_data VALUES (i, 'Name' || i, i * 10);
  7.   END LOOP;
  8. COMMIT;
  9. END insert_test_data;</font>
复制代码


3、调试下:

  1. <font size="3">select count(*) from test_data t; call insert_test_data(1000); truncate table test_data;</font>
复制代码
二、测试工具准备:
1、网上找到:mysql-connector-java-8.0.29.jar(版本不限定),放到Jmeter目录\lib\ext下。
2、网上找或将本地:ojdbc14.jar,放到Jmeter目录\lib下。

三、工具配置及执行:
全局配置如下图:

[attach]146587[/attach]
1、配置JDBC Connection Configuration:
右键,Config Element下添加节点,配置如图:

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

2、配置吞吐量控制器(可跳过):
[attach]146589[/attach]
如图就是占20%的吞吐量。示例中SP占20%,SQL占80%。模拟实际的80%查询,20%写入的场景。

3、配置JDBC Request:
右键,Sampler里找到JDBC Request,添加。
对于存储过程:

[attach]146590[/attach]
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语句:

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

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






欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2