Jmeter测试 Websocket服务器

简介: 使用Jmeter来对websocket服务进行测试

一、Jmeter 安装

在此处下载Jmeter二进制文件,解压进入bin目录,点击 jmeter.bat 。OK,就可以看到下面的界面,当然线程组是不存在的(那是我加的)。
fdf65f4462424db4b871a7e9258db88d.png

这里有几点说明:
jmeter.bat:运行JMeter(默认在GUI模式下)
jmeterw.cmd:在没有 Windows shell 控制台的情况下运行 JMeter(默认在 GUI 模式下)
jmeter-n.cmd:在其上放置 JMX 文件以运行 CLI 模式测试
jmeter-n-r.cmd:在其上放置 JMX 文件以远程运行 CLI 模式测试
jmeter-t.cmd:将 JMX 文件拖放到此文件上以在 GUI 模式下加载它
jmeter-server.bat:以服务器模式启动 JMeter
mirror-server.cmd:以 CLI 模式运行 JMeter 镜像服务器
shutdown.cmd:运行 Shutdown 客户端以正常停止 CLI 模式实例
stoptest.cmd:运行 Shutdown 客户端以突然停止 CLI 模式实例

特殊名称LAST可以与jmeter-n.cmd、jmeter-t.cmd和jmeter-nr.cmd一起使用 ,表示交互式运行的最后一个测试计划。

1.1 自定义 JMeter 的 JVM 设置

在bin目录中创建一个名为setenv.bat,添加下面的代码:

set JVM_ARGS=-Xms1024m -Xmx1024m -Dpropname=value

JVM_ARGS可用于覆盖jmeter.bat脚本中的 JVM 设置,并将在启动 JMeter 时设置,例如 :

jmeter -t test.jmx …

更多的操作可以参照Jmeter用户手册

二、WebSocket插件安装

Jmeter的 WebSocket插件有很多种,这里我们使用JMeter WebSocket Samplers,可以在这里下载

下载最新的就可以,下载后将JAR包拖到 Jmeter安装目录/lib/ext下即可。
a900f432f15b4d9a913c98704109998f.png

之后重启Jmeter,可以看到下图所示即为安装成功:
40f4796a708148f4ad992918dc30f660.png

三、环境准备

我这里是在Win 11上进行的测试,但不管是在那台机器上,都必须修改服务器的最大连接限制。否则,超过服务器限制的连接数就会报错。

3.1 连接数限制修改

  • 首先进入注册表:WIN+R进入运行框,输入:regedit 。
    beed3e86139447178bf5f1bffa56cb39.png
  • 修改注册表:
    进入 [HKEY_LOCAL_MACHINE \System \CurrentControlSet \Services \Tcpip \Parameters]
    
    就是这里:
    d81634f29d2c4200b29ac066007c825b.png

然后添加下面的设置:

最大允许的TCP连接数:TcpNumConnections = 16777214
最大动态端口数 :MaxUserPort = 65534
最大TCB 数量 :MaxFreeTcbs = 16000
最大TCB Hash table 数量 :MaxHashTableSize = 65536

具体操作可以参考:新建 -> QWORD(64位)值(Q)->10进制
835723efd0d54302bdd838cc9b7df89c.png

四、测试

4.1 脚本构建

我的英文不好,所以我选择中文界面,可以这样设置:
e3658cec3c234c1382048bac7a87c626.png

设置完中文看着顺眼多了😁

4.1.1 连接请求

  1. 将线程组添加到测试计划中。
  2. 测试计划 -> 添加 -> 线程(用户) -> 线程组
  3. 将WebSocket Open Connection 采样器添加到线程组
  4. 检查采样器的所有字段并填写以下值:
    • 协议:ws或者wss
    • 服务器名称或 IP:服务器所在的IP
    • 端口:服务对应的端口
    • 路径:对应的路径 可以为空
    • 连接超时(毫秒):20000
    • 读取超时(毫秒):6000
      31797d76bace40dfb17ed745d29e9b80.png

4.1.2 心跳

  1. 线程组 -> 添加 -> 取样器 -> WebSocket Ping/Pong
  2. 采样器指定以下参数:

    • Pong(读取)超时(毫秒):6000

      741f86c81aea460f8c56c52f138d919e.png

4.1.3 WebSocket request-response Sampler

  1. 线程组 -> 添加 -> 取样器 -> WebSocket request-response Sampler
  2. 填写以下值:

    • 连接:use existing connection
    • 数据类型:Text
    • 请求数据:blazemeter
    • 响应(读取)超时(毫秒):6000
      8b504f0f8d2a475580d9c82582872be5.png
  3. 将 WebSocket 请求-响应采样器添加到线程组。下一个采样器将把二进制数据发送到 Echo 服务。

  4. 线程组 -> 添加 -> 取样器 -> WebSocket request-response Sampler
  5. 设置以下字段:
    • 连接:use existing connection
    • 数据类型:Binary
    • 请求数据:0x62 0x6c 0x61 0x7a 0x65 0x6d 0x65 0x74 0x65 0x72
    • 响应(读取)超时(毫秒):6000
      9bb602dc80624966a85554590ff36f08.png

4.1.4 WebSocket Single Write Sampler

  1. 线程组 -> 添加 -> 取样器 -> WebSocket Single Write Sampler
  2. 填写以下值:
    • 连接:use existing connection
    • 数据类型:Text
    • 请求数据:blazemeter-text
      fe522282a7a5403fa788e274ec13fab2.png
  1. 和前面一样,再添加一个发送二进制消息的
  2. 线程组 -> 添加 -> 取样器 ->WebSocket Single Write Sampler
  3. 填写以下值:
    • 连接:use existing connection
    • 数据类型:Binary
    • 请求数据:0x62 0x6c 0x61 0x7a 0x65 0x6d 0x65 0x74 0x65 0x72 0x2d 0x74 0x65 0x78 0x74
      e9d9d43e2bcd4d789b5b5325a32910ad.png

4.1.5 WebSocket Single Read Sampler

  1. 线程组 -> 添加 -> 取样器 -> WebSocket Single Read Sampler
  2. 设置以下字段:
    • 连接:use existing connection
    • 数据类型:Text
    • 响应(读取)超时:6000
      1c3c43581c80443a8e5f7ff8c327990f.png
    1. 线程组 -> 添加 -> 取样器 -> WebSocket Single Read Sampler
    2. 设置以下字段:
    • 连接:use existing connection
    • 数据类型:Binary
    • 响应(读取)超时:6000
      9b675367264a40fcad24c9e9790a69c1.png

4.1.6 WebSocket Close

  1. 线程组 -> 添加 -> 取样器 -> WebSocket Close
  2. 填写以下值:
    • 关闭状态:1000
    • 响应(读取)超时:6000
      a3190ab4a64f4ee29f722af6c72fd6bf.png

4.2 结果查看

  1. 线程组 -> 添加 -> 监听器 -> View Results Tree

五、结果查询

  1. 运行脚本
  2. 查看结果
目录
相关文章
|
3天前
|
测试技术 持续交付 Apache
Python性能测试新风尚:JMeter遇上Locust,性能分析不再难🧐
【10月更文挑战第1天】Python性能测试新风尚:JMeter遇上Locust,性能分析不再难🧐
21 3
|
19小时前
|
分布式计算 Hadoop Shell
Hadoop-35 HBase 集群配置和启动 3节点云服务器 集群效果测试 Shell测试
Hadoop-35 HBase 集群配置和启动 3节点云服务器 集群效果测试 Shell测试
12 4
|
18小时前
|
缓存 NoSQL Ubuntu
大数据-39 Redis 高并发分布式缓存 Ubuntu源码编译安装 云服务器 启动并测试 redis-server redis-cli
大数据-39 Redis 高并发分布式缓存 Ubuntu源码编译安装 云服务器 启动并测试 redis-server redis-cli
12 3
|
1天前
|
弹性计算 安全 Linux
阿里云国际版使用ping命令测试ECS云服务器不通的排查方法
阿里云国际版使用ping命令测试ECS云服务器不通的排查方法
|
3天前
|
缓存 测试技术 Apache
告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
【10月更文挑战第1天】告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
17 4
|
19小时前
|
分布式计算 监控 Hadoop
Hadoop-29 ZooKeeper集群 Watcher机制 工作原理 与 ZK基本命令 测试集群效果 3台公网云服务器
Hadoop-29 ZooKeeper集群 Watcher机制 工作原理 与 ZK基本命令 测试集群效果 3台公网云服务器
9 1
|
1天前
|
存储 数据采集 分布式计算
Hadoop-17 Flume 介绍与环境配置 实机云服务器测试 分布式日志信息收集 海量数据 实时采集引擎 Source Channel Sink 串行复制负载均衡
Hadoop-17 Flume 介绍与环境配置 实机云服务器测试 分布式日志信息收集 海量数据 实时采集引擎 Source Channel Sink 串行复制负载均衡
9 1
|
1月前
|
缓存 Java 测试技术
谷粒商城笔记+踩坑(11)——性能压测和调优,JMeter压力测试+jvisualvm监控性能+资源动静分离+修改堆内存
使用JMeter对项目各个接口进行压力测试,并对前端进行动静分离优化,优化三级分类查询接口的性能
谷粒商城笔记+踩坑(11)——性能压测和调优,JMeter压力测试+jvisualvm监控性能+资源动静分离+修改堆内存
|
1天前
|
Ubuntu API Python
Chat-TTS chat-tts-ui 实机部署上手测试!Ubuntu服务器实机 2070Super*2 8GB部署全流程
Chat-TTS chat-tts-ui 实机部署上手测试!Ubuntu服务器实机 2070Super*2 8GB部署全流程
7 1
ly~
|
4天前
|
域名解析 网络协议 Linux
如何测试 DNS 记录中的反向代理服务器是否生效?
本文介绍了三种测试反向代理服务器配置的方法。首先,通过命令行工具如 `ping`、`nslookup` 和 `dig` 检查域名解析是否指向正确的 IP 地址。其次,利用 Web 浏览器访问域名,验证页面加载正常且请求头信息无误。最后,借助网络抓包工具如 `Wireshark` 和 `tcpdump` 分析数据包,确保请求正确转发并返回预期响应。
ly~
17 2