热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【K6】使用InfluxDB和Grafana图像化展示k6.io的测试数据

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言一:什么是K6二:K6的安装三&#

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档



文章目录


  • 前言
  • 一:什么是K6
  • 二:K6的安装
  • 三:脚本准备
  • 四:执行脚本
  • 五:结果分析
  • 六、输出结果
  • 总结




前言

●🧑个人主页:Damon7575
●📃欢迎点赞👍关注💡收藏💖
●📖既选择了远方,便只顾风雨兼程。
●🤟欢迎大家有问题随时私信我!
●🧐版权:本文由[ Damon7575 ]原创,CSDN首发,侵权必究。



提示:以下是本篇文章正文内容,下面案例可供参考

一:什么是K6

k6 是一种开源、免费的负载测试工具,使工程团队的性能测试变得简单而高效。以开发人员为中心的且可扩展的。

K6 支持的测试类型:
1、冒烟测试:验证系统是否可以处理最小的负载,而不会出现任何问题。
2、负载测试:负载测试主要关注根据每秒并发用户数或请求数评估系统的性能
3、压力测试:压力测试和尖峰测试关注在极端条件下评估系统的极限和稳定性
4、浸泡测试告诉您有关系统在较长时间内的可靠性和性能的信息。

二:K6的安装

官网:
https://k6.io/docs/getting-started/installation/
k6 有适用于 Linux、Mac 和 Windows 的软件包

三:脚本准备

在这里插入图片描述

四:执行脚本

Windows : k6 run 脚本文件
Linux :./k6 run 脚本文件

五:结果分析

在这里插入图片描述
1、checks 成功率
2、data_received 接收数据量
3、data_sent 发送数据量
4、http_req_blocked 在发起请求之前被阻塞的时间
5、http_req_connecting 建立到远程主机的TCP连接所花费的时间
6、http_req_duration 请求的总时间。它等于http reg sending +http reg waiting +http req receiving(即,远程服务器处理请求和响应花了多长 时间,而没有初始DNS查找/连接时间)
7、http_req_failed 请求失败次数
8、http_req_receiving 从远程主机接收响应数据所花费的时间
9、http_req_sending 将数据发送到远程主机所花费的时间
10、http_req_tls_handshaking 与远程主机握手建立TLS会话所花费的时间
11、http_req_waiting 等待远程主机响应所花费的时间
12、http_reqs 吞吐量
13、iteration_duration 迭代持续时间

六、输出结果

K6工具有两种展示测试结果的方法,默认是在执行结束之后会生成一个汇总数据作为测试报告。K6的测试报告是可定制化的。默认的测试报告会包含并发数,断言,请求次数和时间相关的数据统计信息。

K6的测试结果也可以在测试过程中将测试结果实时的同步到其他的外部工具中 (如: InfluxDB, Kafka, StatsD.) ,也可以通过K6 cloud 直观的看到测试结果

使用InfluxDB和Grafana图像化展示k6.io的测试数据:
https://www.leeguangxing.cn/blog_post_76.html
在这里插入图片描述
k6 run --out influxdb=http://172.20.10.10:8086/leeguangxing_load_test index.js



总结

k6 有哪些优势?

基于 JS ES6 的 API。

让你可以集成到自己的工作流和自动化管道中。
让你可以使用同一份 JS 代码来加密请求数据、获取客户端 token 等。
可以模块化、参数化执行编程操作。

简单的 CLI,可用于本地和云执行。这也可集成到自己的 CLI 工具的子功能中。

可以在 Linux、Mac、Windows、Docker 中使用。

有丰富的数据可视化输出方案,并且输出数据带有很多筛选过滤标签。






推荐阅读
  • 本文详细介绍了如何手动编写兼容IE的Ajax函数,以及探讨了跨域请求的实现方法和原理,包括JSONP和服务器端设置HTTP头部等技术。 ... [详细]
  • 本文探讨了缓存系统中的两个关键问题——缓存穿透与缓存失效时的雪崩效应,以及这些问题的解决方案。此外,文章还介绍了数据处理、数据库拆分策略、缓存优化、拆分策略、应用架构演进及通信协议的选择等内容。 ... [详细]
  • 本文探讨了如何利用 Application 对象在 PHP 应用程序中共享数据,特别是在多用户环境中保持数据的一致性和安全性。文章还介绍了 Application 对象的基本结构、方法和事件,并提供了实际应用示例。 ... [详细]
  • 浏览器、中间件与服务器的交互机制
    本文详细探讨了浏览器、中间件和服务器之间的交互过程,特别是HTTP请求的完整流程,包括DNS解析、TCP连接建立及数据传输等关键步骤。 ... [详细]
  • 在CentOS 7中部署Nginx并配置SSL证书
    本文详细介绍了如何在CentOS 7操作系统上安装Nginx服务器,并配置SSL证书以增强网站的安全性。适合初学者和中级用户参考。 ... [详细]
  • 本文探讨了为何采用RESTful架构及其优势,特别是在现代Web应用开发中的重要性。通过前后端分离和统一接口设计,RESTful API能够提高开发效率,支持多种客户端,并简化维护。 ... [详细]
  • Kafka组件详解及工作原理
    本文介绍了Apache Kafka的核心组件及其工作方式,包括生产者(Producer)、消费者(Consumer)、主题(Topic)、代理(Broker)、分区(Partition)、消费者组(Consumer Group)和偏移量(Offset),并探讨了这些组件之间的交互机制。 ... [详细]
  • 本文详细介绍了C++标准模板库(STL)中各容器的功能特性,并深入探讨了不同容器操作函数的异常安全性。 ... [详细]
  • 深入理解FastDFS
    FastDFS是一款高效、简洁的分布式文件系统,广泛应用于互联网应用中,用于处理大量用户上传的文件,如图片、视频等。本文探讨了FastDFS的设计理念及其如何通过独特的架构设计提高性能和可靠性。 ... [详细]
  • PHP中的Content-Type含义及其功能解析
    在PHP中,Content-Type头部信息用于定义资源的媒体类型(MIME类型),这对于确保客户端正确解析服务器响应至关重要。 ... [详细]
  • 本文档详细介绍了服务器与应用系统迁移的策略与实施步骤。迁移不仅涉及数据的转移,还包括环境配置、应用兼容性测试等多个方面,旨在确保迁移过程的顺利进行及迁移后的系统稳定运行。 ... [详细]
  • 深入解析TCP的三次握手、四次挥手及路由器的三层转发机制
    本文详细探讨了OSI七层模型中的传输层,重点分析了TCP协议的连接建立(三次握手)和断开(四次挥手)过程,以及路由器如何在三层网络中实现数据包的高效转发。 ... [详细]
  • 在上一章【第三十九章:基于SpringBoot&Quartz完成定时任务分布式单节点持久化】中我们已经完成了任务的持久化,当我们创建一个任务时任务会被quartz定时任务框架自动持 ... [详细]
  • Web网络基础
    目录儿1使用HTTP协议访问Web2HTTP的诞生2.1因特网的起源2.2互联网、因特网与万维网2.3万维网与HTTP3网络基础TCPIP3.1TCPIP协议族3.2TCPIP的分 ... [详细]
  • 集群与负载均衡技术解析
    本文探讨了集群(Cluster)的概念,即通过网络连接的一组计算机系统,它们作为一个整体提供服务,实现分布式计算。文章还详细介绍了负载均衡技术,旨在提高网络服务的效率和可靠性。 ... [详细]
author-avatar
BigUncle
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有