摘要

本次测试案例主要是分享如何使用JMeter进行websocket协议下的聊天接口性能测试。

包含websocket插件的下载安装、线程组及sampler的设置、csv参数化和组建分布式测试的方法、如何通过调整参数来获得发压机的最大并发数以及对测试过程的总结。

整篇文章只侧重介绍进行websocket测试的思路,对具体工具的使用步骤较少着墨,因为网上已有不少相关介绍文章。

希望本篇文章可以对其他正准备用JMeter进行websocket测试的读者提供一些参考。本人水平有限,如有错误恳请批评指正,感谢!

正文

最近收到一个任务,需要对公司的即时通讯服务端进行压测及聊天接口性能测试,这款即时通讯软件的客户端是通过websocket协议与服务端通信的。

但我之前只做过http协议的测试,websocket协议还是第一次。于是我在网上搜索websocket协议的压测工具,一番比较后选中了JMeter。

选择JMeter的原因有以下几点:

1.JMeter是一款免费开源的软件,有成熟的社区及插件管理工具,满足用户的各种需求。

2.JMeter包含windows、mac、linux多平台版本,对发压机支持较好。

3.JMeter支持GUI和CLI两种操作模式,配置分布式压测步骤简单快捷。

网上有很多关于JMeter的安装使用说明,这里我就不再赘述直接进入websocket的相关测试工作。

安装插件

JMeter不自带websocket功能,需要安装插件,这个插件直接安装最新的就行了,我用的是1.2.8版本。

将下载好的jar包放在JMeter目录下的lib/ext里,然后打开JMeter将websocket sampler勾选上再重启JMeter就安装好JMeterWebsocketSampler插件了。

新建线程组和sampler

这里我先把发压机的线程数设置为100,所有线程立即初始化,运行5分钟。

发压机支持的最大线程数跟发压机的配置有关,我的机器配置是6核12线程,能够设置的最大线程数是160,再多就会运行报错。

但是我的机器线程设置超过100后发送速度也不再增加,想知道自己发压机刚好到达最大发送速度时的线程数,可以设置ramp-up period,比如设置60秒,120个线程,就是平均每秒初始化两个线程,到第60秒时刚好全部初始化完毕。

我自己测试从50秒往后发送速度就不再增加了,所以就设置为100了。

然后添加websocket connection sampler、websocket send sampler、websocket connection close sampler,分别用于建立连接、发送请求、断开连接操作。

由于是压测案例,所以我用到了Loop Controller,可以用于控制sampler的循环次数,并且客户端只管发送,不接收服务端的响应,因为我依靠另一端实际接收到的消息数判断发送是否成功,这样可以避免等待响应阻塞进程。

我的配置如图所示:

我把infinite勾选上了,表示在5分钟的压测时间内让sampler不限次数地循环,这样可以测出sampler在指定时间内能够完成的最大次数。

CSV参数化

对于JMeter来说,每一个线程就是一个用户,所以设置100个线程就需要100个测试用户的账号、密码及发送数据。

添加CSV DATA Set Config步骤,csv的配置我这里不再赘述,不过需要说明的是测试服务端处理聊天消息的性能,最好是多组一对一聊天这样的设置,比如我的就是50个用户分别给另外50个用户发送消息,这样符合真实使用场景,也能测出服务端的真实性能。

分布式测试

按以上步骤找到每台压测机的最大线程数后,就可以开始分布式测试了。

另找一台机器作为主控机,确保每台压测机与主控机的网络互通。在jemter.properties里的remote_hosts添加压测机的ip和端口,server_port是JMeter启动的端口,压测机用jmeter-server启动。

如果主控机与压测机之间的RMI不是SSL连接,记得将server.rmi.ssl.disable=true的注释解开。

server-rmi-localport是用于本机跟其它机器通信的RMI端口,如果要使压测机的压测数据回传主控机,需要将压测机及主控机jemter.properties里的mode=standard注释解开。

保存后主控机使用CLI输入命令jmeter -n -t “Webim Thread Group.jmx” -R x.x.x.x,y.y.y.y -l wbeimlog.jtl -e -o repoort(-R后跟压测机ip,多台用逗号分隔)就可以使用主控机对压测机发送指令了。

压测机接收到指令后会在CLI界面上显示如下信息:

结合压测机回传的数据可以逐台添加压测机以探测服务端的极限性能。汇总的数据在命令行里指定的report目录里,打开index.html页面可以查看统计数据的饼状图,如下图所示:

根据统计数据可以看到发送的总次数、成功次数、错误情况等信息,对测试案例进行调整。到此使用JMeter进行websocket性能测试就算完成了。

测试过程总结

整个测试的关键点有三处:

一是调整发压机参数使并发数达到最大;

二是设置每对聊天账号都是一对一,不等待服务端响应,以便获得最真实的服务端性能;

三是根据压测机回传的数据分析出压测机所需的数量,进而测试出服务端的最大性能。

我这边整个测试工作都处于测试环境进行,取得的测试数据并不能完成代表真实生产环境下的情况,仅可以用作预测生产环境下的性能表现。

最后: 可以关注公众号:伤心的辣条 ! 进去有许多资料共享!资料都是面试时面试官必问的知识点,也包括了很多测试行业常见知识,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!


好文推荐

转行面试,跳槽面试,软件测试人员都必须知道的这几种面试技巧!

面试经:一线城市搬砖!又面软件测试岗,5000就知足了…

面试官:工作三年,还来面初级测试?恐怕你的软件测试工程师的头衔要加双引号…

什么样的人适合从事软件测试工作?

那个准点下班的人,比我先升职了…

测试岗反复跳槽,跳着跳着就跳没了…

性能进阶:使用JMeter进行websocket测试相关推荐

  1. 性能进阶:使用JMeter进行websocket测试【建议收藏】

    本次测试案例主要是分享如何使用JMeter进行websocket协议下的聊天接口性能测试. 包含websocket插件的下载安装.线程组及sampler的设置.csv参数化和组建分布式测试的方法.如何 ...

  2. Jmeter对webSocket测试

    Jmeter对webSocket压测以及观察 Jmeter压测工具 之前用WebSocket开发了消息的即时推送功能,也了解WebSocket的连接是比较占内存的,如果管理不好连接数,很容易触发jvm ...

  3. JMeter之Websocket测试

    上一篇:WebSocket初步的认识 通过上一篇,以及对websocket有个初步的了解,接下来学习如何在JMeter里进行websocket的通讯. websocket插件介绍 如下图,在插件助手里 ...

  4. 如何使用Jmeter对WebSocket进行压力测试

    01 环境准备 Jmeter对WebSocket协议的环境准备: 因为Jmeter本身不支持WebSocket协议的,所以需要安装第三方的插件JMeterWebSocketSampler-1.0.2- ...

  5. Jmeter实现WebSocket协议的接口和性能测试方法

    WebSocket protocol 是HTML5一种新的协议.它实现了浏览器与服务器全双工通信(full-duplex). 浏览器和服务器只需要要做一个握手的动作,然后,浏览器和服务器之间就形成了一 ...

  6. jmeter 高并发测试报告_使用 JMeter 进行压力测试

    原文连接:使用 JMeter 进行压力测试 一.前言 压力测试是每一个Web应用程序上线之前都需要做的一个测试,他可以帮助我们发现系统中的瓶颈问题,减少发布到生产环境后出问题的几率:预估系统的承载能力 ...

  7. jmeter脚本_性能工具之Jmeter脚本python启动

    背景 上一节是shell命令启动Jmeter,担心大家对shell脚本语法不是很熟悉,如果定制自己想要的恐怕不好弄,这次改用python启动脚本,在改造之前大家先了解下Jmeter线程组相关参数,这样 ...

  8. 两款JSON类库Jackson与JSON-lib的性能对比(新增第三款测试)

    本篇文章主要介绍了"两款JSON类库Jackson与JSON-lib的性能对比(新增第三款测试)",主要涉及到两款JSON类库Jackson与JSON-lib的性能对比(新增第三款 ...

  9. 在ASP.NET Core微服务架构下使用数据库切分和扩展, 并用JMeter进行负载测试

    原文链接:https://itnext.io/how-to-scale-an-asp-net-core-microservice-and-sharded-database-load-test-with ...

最新文章

  1. 高并发场景下更新数据库报错,记录一次 MySQL 死锁问题的解决
  2. SAP QM初阶之维护检验计划时可以不用事先创建好检验特性主数据
  3. Laravel 中简约而不简单的 Macroable 宏指令 1
  4. Python中如何查看模块的源码内容
  5. scratch跳一跳游戏脚本_超级丛林跳游戏下载-超级丛林跳最新版下载v1.01.5026 安卓版...
  6. 想旷工被单位开除领取失业金,可是单位不但不开除还给交社保,该怎么办?
  7. 11种刷新按钮的方法
  8. 大学生毕业如何选择职业?
  9. Ubuntu Emacs Fcitx 中文输入法设置
  10. Vue学习之旅Part3:Vue的全局过滤器和私有过滤器
  11. pdca实施的流程图_思维导图丨《高效PDCA工作术》流程图
  12. 基于PT100的温度测量系统设计
  13. 想转行学IT!0基础应该要学习哪个技术
  14. 802.11n和802.11ac的MCS速率表
  15. 投稿开奖丨“轻量应用服务器”征文活动阳光普照奖(8月)开奖啦
  16. Tensorflow-Keras教程
  17. java计算机毕业设计爱心公益网站设计与制作源码+数据库+系统+lw文档+部署
  18. 用Python+ChatGPT
  19. 操作符有哪些?有什么用处?
  20. iMX RT FlexSPI 时序及驱动程序参数设置解析 (一)

热门文章

  1. python爬取网页内容requests_[转][实战演练]python3使用requests模块爬取页面内容
  2. c语言第一周项目,C语言第一周实战
  3. QT中三种构建菜单栏的方法
  4. 面向对象:三大特性与五大原则
  5. Linux开机自动启动ORACLE设置
  6. 机器学习常见的六大错误
  7. 深度了解视频直播CDN技术
  8. MYSQL 浅谈MyISAM 存储引擎
  9. 利用shell找出15分钟内修改的文件
  10. YII 利用Clip构建layout