当前位置: 首页>编程语言>正文

java压测测试什么 java项目压力测试

基于Idea + MybatisX插件快速构建Java项目 JMeter集成测试 压力测试

1 环境

1.1 Idea

1.2 MybatisX插件

java压测测试什么 java项目压力测试,java压测测试什么 java项目压力测试_压力测试,第1张

1.3 创建一个表

CREATE TABLE IF NOT EXISTS public.sys_user
(
    id serial,
    username character varying  NOT NULL,
    password character varying  NOT NULL,
    age smallint  NOT NULL,
    hobby character varying NOT NULL,
    CONSTRAINT sys_user_pkey PRIMARY KEY (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 添加数据源

java压测测试什么 java项目压力测试,java压测测试什么 java项目压力测试_jmeter_02,第2张

2.3 使用MybatisX插件创建 mvc

java压测测试什么 java项目压力测试,java压测测试什么 java项目压力测试_压力测试_03,第3张

java压测测试什么 java项目压力测试,java压测测试什么 java项目压力测试_java_04,第4张

java压测测试什么 java项目压力测试,java压测测试什么 java项目压力测试_压力测试_05,第5张

java压测测试什么 java项目压力测试,java压测测试什么 java项目压力测试_jmeter_06,第6张

注:检查一下生成的代码是否合意

// 注意@TableName(value ="sys_user")及属性的类型
@TableName(value ="sys_user")
@Data
public class SysUser implements Serializable {

    @TableId(type = IdType.AUTO)
    private Integer id;

    private String username;

    private String password;

    private Integer age;

    private String hobby;

    @TableField(exist = false)
    private static final long serialVersionUID = 1L;
}

mapper类,可以加上@Mapper ,或在主类加上@MapperScan(“com.wrp.jmeter.mapper”)

@Mapper
public interface SysUserMapper extends BaseMapper<SysUser> {

}

@MapperScan("com.wrp.jmeter.mapper")
@SpringBootApplication
public class JmeterDemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(JmeterDemoApplication.class, args);
    }

}

2.4 开发controller

@RestController
@RequestMapping("/user")
@AllArgsConstructor
public class SysUserController {

    private SysUserService sysUserService;

    @PostMapping("/register")
    public R register(@RequestBody RegisterUser registerUser) {
        SysUser sysUser = new SysUser();
        BeanUtils.copyProperties(registerUser, sysUser);
        boolean saved = sysUserService.save(sysUser);
        if(saved) {
            return R.success();
        } else {
            return R.error("注册失败");
        }
    }

    @PostMapping("/login")
    public R login(@RequestBody LoginUser loginUser) {
        SysUser sysUser = sysUserService.login(loginUser);
        if(sysUser != null) {
            return R.success(sysUser.getId());
        } else {
            return R.error("登录失败");
        }
    }

    @GetMapping("/detail")
    public R detail(@RequestParam("id") Integer id) {
        return R.success(sysUserService.getById(id));
    }
}

其他代码省略,easy

3 Jmeter测试

模拟测试场景: 登录成功后根据id查询用户详情

  1. 添加线程组
  2. 添加登录接口Http请求取样器

java压测测试什么 java项目压力测试,java压测测试什么 java项目压力测试_java压测测试什么_07,第7张

  1. 添加前置处理器 请求头管理 乱码问题
Content-Type: application/json;charset=UTF-8
  1. 添加后置处理器 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 默认值
  1. 添加详情接口Http请求取样器

使用后置处理器的变量 ${变量名}

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fhd9Ooh8-1687334998322)(C:\Users\13456\AppData\Roaming\Typora\typora-user-images\image-20230621153923101.png)]

  1. 添加查看结果树和汇总报告监听器
  2. 配置线程组参数

三个线程,每个线程跑100次

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rt3xHMGB-1687334998322)(C:\Users\13456\AppData\Roaming\Typora\typora-user-images\image-20230621154038179.png)]

  1. 查看结果树及汇总报告

java压测测试什么 java项目压力测试,java压测测试什么 java项目压力测试_集成测试_08,第8张

4 常用指标

4.1 QPS

Queries Per Second,意思是每秒查询率

主要针对查询接口

4.2 TPS

Transactions Per Second,意思是每秒事务数

一个事务中,可能会调用多个接口

4.3 提高TPS的方法

  1. 优化数据库
  1. 连接数
  2. SQL
  1. 优化服务的配置
  1. 优化数据库连接池参数
  2. 优化tomcat参数
  3. 优化JVM参数 -Xms -Xmx等
  4. 优化代码
  1. 更好的硬件设备
  2. 单机 -> 集群



https://www.xamrdz.com/lan/5yv1963109.html

相关文章: