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

JMeter WebSocket 压测详细步骤(支持 ws+proto 协议)

一、环境准备

  1. 安装 Java

    • JMeter 依赖 Java 环境,确保已安装 JDK 8+。

    • 验证安装:终端输入 java -version,显示版本信息即可。

  2. 下载 JMeter

    • 官网下载最新版:Apache JMeter

    • 解压到任意目录(如 /opt/jmeter)。

  3. 安装插件管理器

    • 下载 jmeter-plugins-manager-1.10.jar,放入 JMETER_HOME/lib/ext 目录。

    • 重启 JMeter,菜单栏 Options → Plugins Manager 可见。

  4. 安装 WebSocket 插件

    • 打开插件管理器,搜索 WebSocket,安装以下插件:

      • WebSocket Samplers by Peter Doornbosch

      • Custom Thread Groups(可选,用于复杂压测模型)

  5. Protocol Buffers (proto) 支持

    • 下载 protobuf-java-x.x.x.jar(版本需与服务器匹配),放入 JMETER_HOME/lib

    • 在测试计划中通过 JSR223 Sampler 或 BeanShell 调用 proto 序列化/反序列化。


二、压测实例:WebSocket + Proto 协议
场景描述
  • 模拟 100 用户并发连接 WebSocket 服务器(ws://your-server:8080/chat)。

  • 每个用户发送 proto 编码的消息(如 ChatMessage.proto),并接收响应。

步骤 1:定义 Proto 文件

// ChatMessage.proto
syntax = "proto3";
message ChatMessage {string user_id = 1;string content = 2;int64 timestamp = 3;
}
 
步骤 2:生成 Java 类

protoc --java_out=./src ChatMessage.proto
 
  • 将生成的 ChatMessage.java 编译为 .class 文件,打包成 chat-message.jar,放入 JMETER_HOME/lib


步骤 3:配置 JMeter 测试计划
  1. 创建线程组

    • 右键 Test Plan → Add → Threads (Users) → Thread Group

    • 参数:

      • Number of Threads (Users): 100

      • Ramp-Up Period: 10 (秒内启动全部用户)

      • Loop Count: Forever(持续压测)

  2. 添加 WebSocket 连接控制器

    • 右键 Thread Group → Add → Config Element → WebSocket Connection Configuration

    • 参数:

      • Server URL: ws://your-server:8080/chat

      • Protocol: ws

      • Connection Timeout: 5000 (ms)

  3. 添加 WebSocket 请求采样器

    • 右键 Thread Group → Add → Sampler → WebSocket Open Connection

    • Name: Open Connection

    • Implementation: RFC6455 (WebSocket v13)

  4. 发送 Proto 编码消息

    • 添加 JSR223 Sampler(使用 Groovy 脚本处理 proto):

    import com.example.ChatMessage;// 创建 proto 对象
    def message = ChatMessage.newBuilder().setUserId("user_${ctx.getThreadNum()}").setContent("Hello from JMeter").setTimestamp(System.currentTimeMillis()).build();// 序列化为字节流
    byte[] payload = message.toByteArray();
    vars.put("protoPayload", payload); // 存储到变量
     
  5. 发送二进制消息

    • 添加 WebSocket Send Sampler

      • Message Type: Binary

      • Payload: ${protoPayload}(引用脚本生成的变量)

  6. 接收响应并断言

    • 添加 WebSocket Read Sampler

      • Timeout: 2000 ms

      • Expect Close: No

    • 添加 JSR223 Assertion 解析 proto:

    import com.example.ChatMessage;byte[] response = prev.getResponseData();
    ChatMessage parsed = ChatMessage.parseFrom(response);
    if (!parsed.getContent().contains("ACK")) {AssertionResult.setFailure(true);AssertionResult.setFailureMessage("Invalid response: " + parsed.getContent());
    }
     
  7. 添加监听器

    • View Results Tree(调试用,压测时禁用)

    • Summary Report / Aggregate Report

    • Response Time Graph


三、执行压测
  1. 保存测试计划为 websocket-proto.jmx

  2. 命令行运行(避免 GUI 资源消耗):

    jmeter -n -t websocket-proto.jmx -l result.jtl
     
  3. 使用 JMeter Plugins 生成报告:

    JMETER_HOME/bin/jmeter -g result.jtl -o report/
     

四、常见问题
  • Proto 类未找到:确认 chat-message.jar 在 lib 目录。

  • WebSocket 连接失败:检查防火墙、服务器是否支持 ws(非 wss)。

  • 高并发下连接拒绝:调整服务器最大连接数,或使用分布式压测。


通过以上步骤,即可完成基于 ws+proto 协议的 WebSocket 压测。根据实际业务调整消息内容、并发模型及断言逻辑。

http://www.xdnf.cn/news/236413.html

相关文章:

  • flutter 专题 五十六 Google 2020开发者大会Flutter专题
  • 驱动车辆诊断测试创新 | 支持诊断测试的模拟器及数据文件转换生成
  • 斯坦福RGA软件 老版本和兼容Windows 11版本可选
  • 在 OpenSearch 中建立有效的混合搜索: 技术和最佳实践
  • PCB设计工艺规范(四)安规要求
  • 变量char2、*char2、pChar3、*pChar3的存储位置
  • 冰冰一号教程网--介绍采用vuepress搭建个人博客
  • CrowdStrike推出新型工具防御恶意AI模型与数据窃取
  • 「Mac畅玩AIGC与多模态10」开发篇06 - 使用自定义翻译插件开发智能体应用
  • ai改写智能助手在线润色,高效产出优质文章!
  • Qt -DFS可视化
  • 乐西高速大凉山1号隧道实现双幅贯通:成都到昭觉9小时变3.5小时
  • 代码随想录打卡|Day31动态规划(最后一块石头的重量2、目标和、一和零)
  • 分割链表题解
  • 2025年“深圳杯”数学建模挑战赛A题-芯片热弹性物理参数估计
  • 记一次 MyBatis 缓存引发的问题
  • 高级测试工程师 的面试题汇总
  • 实验-单总线温度采集与显示(汇编语言与接口技术)
  • 视觉问答大模型速递:Skywork-R1V2-38B
  • 【人工智能】深入探索Python中的自然语言理解:实现实体识别系统
  • 第二部分:赤色的世界
  • 提高设计的综合性能
  • ESP32开发之freeRTOS的信号量
  • 免费在Colab运行Qwen3-0.6B——轻量高性能实战
  • Learning vtkjs之ImplicitBoolean
  • Java大师成长计划之第8天:Java线程基础
  • 树状结构转换工具类
  • 沙箱逃逸-通过题解了解沙箱逃逸
  • Flow Matching 是什么?
  • 如何做表征对齐?