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

K6性能测试及生成Html压测报告

一、引言:

k6是一款开源负载测试工具,由Grafana Labs开发维护,专注于现代云环境和微服务架构 的高并发压测。它采用Go语言编写,使用JavaScript(ES6)作为脚本语言。还提到它特别适合CI/CD集成和自动化性能测试。

二、下载安装:

https://github.com/grafana/k6/releases

下载后直接安装即可

三、运行:

cmd打开命令行,输入:k6,验证是否安装成功

四、编写压测脚本

命名js脚本名称为demo.js

// 使用 require 引入 k6 模块consthttp=require('k6/http');const{check}=require('k6');// 引入远程报告生成模块(使用 require)const{htmlReport}=require('https://raw.githubusercontent.com/benc-uk/k6-reporter/main/dist/bundle.js');// 配置选项(保持 export 不变)exportconstoptions={vus:30,duration:'60s',thresholds:{http_req_duration:['p(95)<500'],http_req_failed:['rate<0.01'],},};// 主测试函数(VU 执行的代码)exportdefaultfunction(){// 根据数据内容,这里应该是 POST 请求constres=http.get('http://127.0.0.1:5012/products',{headers:{'Content-Type':'application/json'},});check(res,{'status is 200':(r)=>r.status===200,});}// 摘要报告函数(必须定义在全局)exportfunctionhandleSummary(data){return{'D:\summary.html':htmlReport(data),// 输出报告到指定路径};}

五、运行脚本:

k6 runC:\Users\Administrator\Desktop\demo.js

六、生成压测报告路径

七、查看压测报告:

八、HTTP 请求各阶段耗时指标​​

  1. ​​http_req_duration​​
    ​​含义​​:​​HTTP 请求总耗时​​,从请求开始到完整接收响应的时间(包含 http_req_sending、http_req_waiting、http_req_receiving)。
    ​​计算公式​​:http_req_sending + http_req_waiting + http_req_receiving。
    ​​分析重点​​:
    ​​系统整体性能​​:若该值过高,表明请求处理链路存在瓶颈(如网络延迟、服务器处理慢)。
    ​​百分位数(p90/p95)​​:反映高延迟请求的分布(例如 p(90)=500ms 表示 90% 请求耗时 ≤500ms)。
  2. ​​http_req_waiting​​
    ​​含义​​:​​服务器处理时间​​(TTFB, Time to First Byte),即从发送请求到接收到服务器第一个字节的耗时。
    ​​关键场景​​:
    若该值过高 → 服务器处理能力不足(如 CPU 过载、数据库查询慢)。
    示例:avg=150ms 表示平均等待服务器响应 150ms。
  3. ​​http_req_connecting​​
    ​​含义​​:​​TCP 连接建立时间​​,从发起请求到完成 TCP 握手的时间。
    ​​问题定位​​:
    高值 → DNS 解析慢或网络路由问题(如跨地域请求)。
    示例:max=100ms 表示最慢一次 TCP 连接耗时 100ms。
  4. ​​http_req_tls_handshaking​​
    ​​含义​​:​​TLS/SSL 握手时间​​,仅在使用 HTTPS 时出现。
    ​​优化方向​​:
    高值 → 服务器证书配置问题(如密钥过长、未启用会话复用)。
    示例:avg=50ms 表示平均 TLS 握手耗时 50ms。
  5. ​​http_req_sending​​
    ​​含义​​:​​请求发送时间​​,从开始发送请求头到完成发送请求体的耗时。
    ​​影响因素​​:
    请求体大小(如上传大文件时该值较高)。
    通常较低(毫秒级),若异常高 → 客户端网络问题。
  6. ​​http_req_receiving​​
    ​​含义​​:​​响应接收时间​​,从接收第一个响应字节到完整接收响应体的耗时。
    ​​关联因素​​:
    响应体大小(如下载大文件时该值显著升高)。
    示例:avg=200ms 表示平均接收数据耗时 200ms。
    ​​二、请求阻塞与迭代整体耗时​​
  7. ​​http_req_blocked​​
    ​​含义​​:​​请求阻塞时间​​,包括 DNS 查询、TCP 连接等待、TLS 握手前的等待。
    ​​常见原因​​:
    高值 → 客户端资源不足(如线程池耗尽)或网络防火墙拦截。
    示例:p(95)=300ms 表示 95% 的请求阻塞时间 ≤300ms。
  8. ​​iteration_duration​​
    ​​含义​​:​​单次迭代总耗时​​,包含脚本逻辑执行(如多个 HTTP 请求)和 sleep() 等待时间。
    ​​与 http_req_duration 区别​​:
    一个迭代可能包含多个 HTTP 请求(如登录→查询→登出)。
    示例:avg=1.2s 表示用户完整操作链路的平均耗时。

http://www.jsqmd.com/news/500342/

相关文章:

  • 高级 RAG 查询技术实战教程(非常详细),查询转换与分解从入门到精通,收藏这一篇就够了!
  • 3300mm四辊可逆精轧机(CAD)
  • 一天一个开源项目(第54篇):Supabase - 开源的 Postgres 开发平台,Firebase 替代方案
  • 用电脑闹钟神器有效管理时间并增添乐趣
  • 论文全红怎么救?2026免费降AI天花板出炉:实测10款主流平台,硬生生把98%按到6%!
  • 整数和浮点数在内存中存储的区别
  • [mpv] 通过 JSON IPC 控制 mpv 播放器
  • 第2章 文件和用户管理
  • 金仓数据库在文档型数据迁移中的实践复盘:从MongoDB协议兼容到政务系统平滑替换
  • 算法设计与分析-习题9.4
  • OpenClaw 第十三篇:核心技术实现拆解——从指令输入到执行落地的全链路原理
  • godot中文不显示,仅显示编码,是因为没设置字体,设置字体就好了
  • 2025 CCF 非专业级软件能力认证 解析
  • 2026年靠谱的北京酒店木门品牌推荐:江苏民宿木门/新疆工程木门正规生产厂家推荐 - 行业平台推荐
  • 关于 HarmonyOS 版本的简述
  • 参考文献崩了?AI论文写作软件,千笔AI VS 笔捷Ai,毕业论文全流程必备!
  • nodejs+vue基于springboot的车辆二手汽车交易综合服务平台
  • LeetCode Hot100第二题 字母异位词分组
  • 2026年热门的有机水溶肥品牌推荐:含氨基酸水溶肥/陕西中量元素水溶肥口碑厂家汇总 - 行业平台推荐
  • linux内核 Netfilter
  • 程序员必看:大模型参数高效微调(PEFT)全攻略,建议收藏
  • ESP-IDF 简介
  • 学生3类课堂行为(举手、阅读、书写)识别目标检测数据集(近 4200 张图片已标注)| YOLO训练数据集 AI视觉检测
  • 四轮转向汽车稳定性控制策略:从理论到实践
  • 东华OJ-进阶题-19-排队打水问题(C++)
  • OpenClaw部署 + 多agent智能体协作
  • 无刷直流电机自抗扰控制策略:转速转矩双闭环系统的高效调节机制
  • 三相静止无功发生器SVG并网仿真模型说明报告
  • OpenClaw 全网板块公开的数据自动收集(2026 版)
  • 2026年比较好的二通电动球阀厂家推荐:水处理电动球阀生产厂家推荐几家 - 行业平台推荐