基于Idea + MybatisX插件快速构建Java项目 JMeter集成测试 压力测试
1 环境
1.1 Idea
1.2 MybatisX插件
1.3 创建一个表
CREATETABLEIFNOTEXISTSpublic.sys_user
(
id serial,
username charactervaryingNOTNULL,
password charactervaryingNOTNULL,
age smallintNOTNULL,
hobby charactervaryingNOTNULL,CONSTRAINT sys_user_pkey PRIMARYKEY(id))
2 创建项目
2.1 引入依赖
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.postgresql</groupId><artifactId>postgresql</artifactId></dependency><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.2</version></dependency>
2.2 添加数据源
2.3 使用MybatisX插件创建 mvc
注:检查一下生成的代码是否合意
// 注意@TableName(value ="sys_user")及属性的类型@TableName(value ="sys_user")@DatapublicclassSysUserimplementsSerializable{@TableId(type =IdType.AUTO)privateInteger id;privateString username;privateString password;privateInteger age;privateString hobby;@TableField(exist =false)privatestaticfinallong serialVersionUID =1L;}
mapper类,可以加上@Mapper ,或在主类加上@MapperScan(“com.wrp.jmeter.mapper”)
@MapperpublicinterfaceSysUserMapperextendsBaseMapper<SysUser>{}@MapperScan("com.wrp.jmeter.mapper")@SpringBootApplicationpublicclassJmeterDemoApplication{publicstaticvoidmain(String[] args){SpringApplication.run(JmeterDemoApplication.class, args);}}
2.4 开发controller
@RestController@RequestMapping("/user")@AllArgsConstructorpublicclassSysUserController{privateSysUserService sysUserService;@PostMapping("/register")publicRregister(@RequestBodyRegisterUser registerUser){SysUser sysUser =newSysUser();BeanUtils.copyProperties(registerUser, sysUser);boolean saved = sysUserService.save(sysUser);if(saved){returnR.success();}else{returnR.error("注册失败");}}@PostMapping("/login")publicRlogin(@RequestBodyLoginUser loginUser){SysUser sysUser = sysUserService.login(loginUser);if(sysUser !=null){returnR.success(sysUser.getId());}else{returnR.error("登录失败");}}@GetMapping("/detail")publicRdetail(@RequestParam("id")Integer id){returnR.success(sysUserService.getById(id));}}
其他代码省略,easy
3 Jmeter测试
模拟测试场景: 登录成功后根据id查询用户详情
- 添加线程组
- 添加登录接口Http请求取样器
- 添加前置处理器 请求头管理 乱码问题
Content-Type: application/json;charset=UTF-8
- 添加后置处理器 JSON提取器
- apply to 应用范围 - Main sample and sub-samples 主取样器及子取样器- Main sample only 仅主取样器- Sub-samples only 仅子取样器- JMeter Variable Name to use Jmeter变量名
- Names of Created variables 变量名
- Json Path expressions json路径表达式 $代表结果
- Match NO.(0 for Random)
0表示随机;
n取第几个匹配值;
-1匹配所有。
若只要获取到匹配的第一个值,则填写1
- compute concatenation var(suffix_ALL) 如果找到许多结果,则插件将使用’ , '分隔符将它们连接起来,并将其存储在名为 _ALL的var中
- Default Values 默认值
- 添加详情接口Http请求取样器
使用后置处理器的变量 ${变量名}
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fhd9Ooh8-1687334998322)(C:\Users\13456\AppData\Roaming\Typora\typora-user-images\image-20230621153923101.png)]
- 添加查看结果树和汇总报告监听器
- 配置线程组参数
三个线程,每个线程跑100次
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rt3xHMGB-1687334998322)(C:\Users\13456\AppData\Roaming\Typora\typora-user-images\image-20230621154038179.png)]
- 查看结果树及汇总报告
4 常用指标
4.1 QPS
Queries Per Second,意思是每秒查询率
主要针对查询接口
4.2 TPS
Transactions Per Second,意思是每秒事务数
一个事务中,可能会调用多个接口
4.3 提高TPS的方法
- 优化数据库 1. 连接数2. SQL
- 优化服务的配置 1. 优化数据库连接池参数2. 优化tomcat参数3. 优化JVM参数 -Xms -Xmx等4. 优化代码
- 更好的硬件设备
- 单机 -> 集群
版权归原作者 Pardon_wang 所有, 如有侵权,请联系我们删除。