Mac使用K6工具压测WebSocket

news2025/1/11 10:04:27
  1. commend+空格 打开终端,安装k6
brew install k6
  1. 验证是否安装成功
k6 version
  1. 设置日志级别为debug
 export K6_LOG_LEVEL=debug
  1. 执行脚本(进入脚本所在文件夹下)
`k6 run --vus 100  --duration 10m --out csv=result.csv scri`pt.js 

脚本解释:
当前目录下的script.js脚本,用户数100,持续时间10分钟,运行结果存放到result.csv

script脚本内容

import ws from 'k6/ws';
import { check } from 'k6';
export const options = {
    vus: 20, // 设置虚拟用户数为50
    duration: '5m', // 持续运行时间为5分钟
};
export default function () {
    const url = '';接口地址
    const idToken = ''; //  id-token
    const requestBody = JSON.stringify({
        "msg": "测试", //请求体      
    });
    const params = {
        headers: {
             'id-token': idToken
        }
    };
    // 建立 WebSocket 连接
    const response = ws.connect(url, params, function (socket) {
        // 发送请求
        socket.send(requestBody);
        // 接收响应
        socket.on('message', function (message) {
            console.log(`Received message: ${message}`);
        });
    });
    // 检查连接是否成功
    check(response, { 'WebSocket connected successfully': (r) => r && r.status === 101 });
}

成功截图
在这里插入图片描述
失败截图
在这里插入图片描述

字段解释
  • WebSocket connected successfully: 表示 WebSocket 是否成功连接。在这个例子中,连接失败了 58448 次,成功了 130 次。
  • checks: 表示执行的检查数量和通过的检查数量。在这个例子中,执行了 58578 次检查,其中通过了 130 次。
  • data_received: 表示接收到的数据量。这里接收了总共约 27 MB 的数据,平均每秒接收约 45 KB。
  • data_sent: 表示发送的数据量。这里发送了总共约 43 MB 的数据,平均每秒发送约 72 KB。
  • **iteration_duration:**表示每个迭代的持续时间。avg 表示平均持续时间,min 表示最短持续时间,med 表示中位数持续时间,max 表示最长持续时间,p(90) 和 p(95) 分别表示第 90 百分位和第 95 百分位的持续时间。
  • iterations: 表示完成的迭代数量。这里完成了 58578 个迭代,平均每秒完成约 97.52 个迭代。
  • vus: 表示当前运行的虚拟用户数量。这里虚拟用户数量一直保持在 100。
  • **vus_max:**表示虚拟用户数量的最大值。这里最大同时运行的虚拟用户数量为 100。
  • **ws_connecting:**表示 WebSocket 连接中的会话的持续时间统计。与 iteration_duration 类似,提供了连接中会话的平均持续时间、最短持续时间、中位数持续时间、最长持续时间以及第 90 和第 95 百分位的持续时间。
  • ws_msgs_sent: 表示发送的 WebSocket 消息数量。在这个例子中,发送了 130 条消息,平均每秒发送约 0.22 条消息。
  • **ws_session_duration:**表示 WebSocket 会话的持续时间统计,提供了与 ws_connecting 类似的统计信息。
  • ws_sessions: 表示 WebSocket 会话数量。这里共有 58578 个 WebSocket 会话,在测试期间平均每秒完成约 97.52 个 WebSocket 会话。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1471586.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

亿道丨三防平板丨手持平板丨加固平板丨助力地震救援

自土耳其发生7.8级大地震以来,一直都牵动着世人的心。2023年2月10日,据法新社最新消息,强震已造成土耳其和叙利亚两国超2万人遇难。报道称,相关官员和医护人员表示,地震造成土耳其17674人死亡,叙利亚则有33…

基于Springboot的旅游网管理系统设计与实现(有报告)。Javaee项目,springboot项目。

演示视频: 基于Springboot的旅游网管理系统设计与实现(有报告)。Javaee项目,springboot项目。 项目介绍: 采用M(model)V(view)C(controller)三层…

第二代80KM高效远距离传输:100G ZR4光模块的应用与发展

随着信息时代的发展,数据传输的需求日益增长,而光模块作为数据中心和网络基础设施的关键组成部分,其性能和应用范围也在不断扩大。易天光通信的第二代100G ZR4 80KM光模块很好的满足了当代社会通信网络的需求。本文易天光通信将探讨第二代高效…

3款黑科技软件,却常被错认是微软开发,纯国产的它功能逆天

美丽的外表往往大同小异,而实用的软件却是难得一遇的珍品。尤其是最后一款国产软件,尽管许多人都在使用,但却常常因为误解而闹出笑话。 1、PhotoDemon 这款由国外技术专家开发的免费、开源图片编辑工具,体积小巧,仅需…

Nacos简易示例

目录 步骤: 1. 下载并启动 Nacos Server 2. 创建用户订单微服务 2.1 创建 Spring Boot 项目 2.2 添加依赖 2.3 配置 Nacos 2.4 编写业务逻辑 3. 注册服务到 Nacos 4. 测试服务 Nacos 是一个开源的服务发现和配置管理系统,可以用于微服务架构中的…

Python 鼠标模拟

鼠标模拟即:通过python 进行模拟鼠标操作 引入类库 示例如下: import win32api import win32con import time 设置鼠标位置 设置鼠标位置为窗口中的回收站。 示例如下: # 设置鼠标的位置 win32api.SetCursorPos([30, 40]) 双击图标 设置…

项目:shell实现多级菜单脚本编写

目录 1. 提示 2. 演示效果 2.1. 一级菜单 2.2. 二级菜单 2.3. 执行操作 3. 参考代码 1. 提示 本脚本主要实现多级菜单效果,并没有安装LAMP、LNMP环境,如果要用在实际生成环境中部署LNMP、LAMP环境,只需要简单修改一下就可以了。 2. 演…

自动换刀主轴应用领域有哪些?

自动换刀主轴是一种先进的机床技术,能够实现快速、准确地更换刀具,提高加工效率和精度,因此在现代制造业中得到了广泛应用。 一、自动换刀主轴的应用领域 1.汽车制造业 汽车制造业是自动换刀主轴应用最广泛的领域之一。在汽车制造过程中&am…

DWT硬件延时

DWT硬件延时 文章目录 DWT硬件延时软件&硬件延时方案软件延时硬件延时方案 DWT硬件延时方案DWT硬件延时方案DEMCR寄存器DWT硬件延时方案实现延时初始化:US延时:MS延时: 软件&硬件延时方案 软件延时 static void Delay(uint32_t cou…

Maven【1】(命令行操作)

文章目录 一丶创建maven工程二、理解pom.xml三、maven的构建命令1.编译操作2.清理操作3.测试操作4.打包操作5.安装操作 一丶创建maven工程 首先创建这样一个目录,然后从命令行里进入这个目录: 然后接下来就在这个命令行里进行操作了。 这个命令是&…

Unity中URP实现水体(水下的扭曲)

文章目录 前言一、使用一张法线纹理,作为水下扭曲的纹理1、在属性面板定义一个纹理,用于传入法线贴图2、在Pass中,定义对应的纹理和采样器3、在常量缓冲区,申明修改 Tilling 和 Offset 的ST4、在顶点着色器,计算得到 应…

代码随想录算法刷题训练营day23

代码随想录算法刷题训练营day23:LeetCode(669)修剪二叉搜索树、LeetCode(108)将有序数组转换为二叉搜索树、LeetCode(538)把二叉树转化为累加树 LeetCode(669)修剪二叉搜索树 题目 代码 /*** Definition for a binary tree node.* public class TreeNode {* …

使用解决方案为PowerApps搭建测试环境

为Power Apps搭建另外一套环境 背景描述环境准备开发环境开发项目项目介绍开发环境SharePoint准备测试环境SharePoint准备解决方案创建创建解决方案环境变量准备创建站点环境变量创建文档库环境变量解决方案中创建Apps解决方案中创建power automate测试查看流运行记录查看Share…

TLS1.2抓包解析

1.TLS1.2记录层消息解析 Transport Layer SecurityTLSv1.2 Record Layer: Handshake Protocol: Client HelloContent Type: Handshake (22)Version: TLS 1.0 (0x0301)Length: 253Content Type:消息类型,1个字节。 i 0Version:协议版本&…

并发情况下数据校验-基于数据库实现

并发情况下数据校验-基于数据库实现 数据库行锁原理实际操作数据准备开启事务,更新数据 项目实战项目配置多线程测试 在开发过程中,我们会遇到校验数据的唯一性,数据更新之后是否超过设置的阈值等等。并发情况下数据校验常见方式有使用分布式…

辽宁博学优晨教育视频剪辑培训探索学习新意义

在当今数字化快速发展的时代,视频已成为信息传达的重要载体。辽宁博学优晨教育视频剪辑培训应运而生,不仅为学员提供了专业的学习平台,更在探索学习的意义方面赋予了新的内涵。 视频剪辑作为现代媒体行业的重要技能,其学习意义不仅…

高速稳定、网络隔离,解析“向日葵控控”远控方案在医疗行业应用

在医疗大健康领域,依托高速发展的信息化技术加速布局智能化,通过远程手段提高医疗服务质量、促进医疗资源共享、提升医疗工作效率,已成为医院和各类社区诊所等提供关键医疗服务部门近年来的发展目标之一。 同时,根据医疗领域的特殊…

点云数据处理常用外部库(C++/Windows)的项目配置

一、点云数据处理常用外部库(C版本)的下载安装与项目配置 (一)PCL 基于VS2019编程平台的PCL外部库下载安装及项目配置已有大量博客,本文不再赘述。具体下载安装及项目配置流程可参考外部库编译配置参考资料/*1*/ 。需…

linux+fortify

系统版本:Ubuntu22.04桌面版 一:登录root用户关闭防火墙 sudo passwd root systemctl stop ufw.service systemctl disable ufw.service 二:开启ssh服务 sudo apt update sudo apt install openssh-server sudo systemctl start ssh sudo systemctl status ssh连接上WinS…