基于k6和python进行自动化性能测试
时间:2023-06-25 13:40:57来源:博客园
摘要:在性能测试中,达到相应的性能指标对于一个软件来说十分重要,在本文中,将介绍一种现代化性能测试工具k6。

本文分享自华为云社区《基于k6和python进行自动化性能测试》,作者: 风做了云的梦。

当我们开发完成一个应用程序时,往往需要对其进行性能测试,以帮助我们更好的优化程序以及发现程序中的一些bug。在性能测试中,达到相应的性能指标对于一个软件来说十分重要,在本文中,将介绍一种现代化性能测试工具k6。


(资料图片)

k6是一个开源工具,基于JavaScript可以编写k6的测试脚本,测试Web应用程序以及API的性能,支持HTTP等多种协议,可以很好地模拟各种高负载场景,充分验证程序稳定性和性能。k6支持Linux、MacOS等多个平台,通过k6官网根据提示即可在各个平台快速安装k6,终端输入k6 version出现如下显示说明安装成功。

以下是一个简单的k6测试脚本,通过k6的HTTP API模拟Get请求,并且休眠一秒钟:K

import http from "k6/http";import { sleep } from "k6";export default function () { http.get("https://test-api.com"); sleep(1);}

通过执行下面这行代码,运行脚本,即可对服务完成测试。

k6 run test-script.js

k6提供了丰富的功能,以下是k6常用的一些API,具体可以参考官网文档介绍:

- http.get(url, [options]):发送GET请求。- http.post(url, body, [options]):发送POST请求。- check(res, checks):检查响应是否符合预期。- group(name, func):将一组请求分组并统计性能指标。- sleep(duration):休眠指定的时间。

k6的测试结果包括以下一些指标,可以根据这些指标,更好的优化程序。

- VUs:虚拟用户的数量。- Iterations:迭代次数。- RPS:每秒钟的请求数。- Duration:测试持续时间。- Data Sent/Received:发送和接收的数据量。- Checks:检查的数量。- Status codes:响应状态码的数量。- Errors:错误的数量。- Latency distribution:延迟分布。

通过Python和k6你可以更加高效的完成符合自己要求的自动化测试,Python可以提供非常多的工具库,用来收集处理k6返回的结果。 我们可以编写以下k6测试脚本,并且通过Python去执行它,相关注释我已经标注出来,在handleSummary函数中,我们可以通过metrics来获取各种测试信息,具体如代码所示,可以参考官网关于metrics的介绍,同时自定义环境变量的使用也十分方便,可以参考代码中的使用方式。

import http from "k6/http";import { check, sleep} from "k6";import {Rate} from "k6/metrics";export default function() {    #post请求所需要的body体 let requestBody = { "xxx":[ "xxxxx"        ], "xxxx": __ENV.MyVar # MyVar为自定义的环境变量,可以通过__ENV调用,在执行脚本时可直接通过MyVar=xxx传值    };    #url const url = "http://example.com"; const payload = JSON.stringify(requestBody); const params = {    headers: { "Content-Type": "application/json",        },    timeout: "100s" #每个请求的超时时间    }; let res = http.post(url, payload, params);    #检测结果是否是200OK check(res, { "status is 200": (r) => r.status === 200 });}export function handleSummary(data) {        #通过data.metrics中的字段可以获取你想要的一些信息,例如每个请求的持续时间和吞吐量 const time = `${data.metrics.http_req_duration.values.avg.toFixed(3)}`; const rps = `${data.metrics.http_reqs.values.rate.toFixed(3)}`; const res = `${time} ${rps}`;         console.log(res); # 利用console.log可以将内容打印到控制台 return {stdout : res}; #输出到标准输出}

如下是一个Python代码示例,相关代码已经注释,通过Python中的subprocess模块执行k6脚本,并且捕获k6脚本的输出,通过pandas库进行整理输出到excel中。还可以通过argparse库解析命令行参数传入k6脚本中,更加灵活,高效。

# -*- coding: utf-8 -*-import subprocessfrom alive_progress import alive_bar # 非常丰富的进度条工具库from tqdm import tqdm # 进度条工具库import pandas as pd # 可以用来处理文本excel,csv等from collections import OrderedDictimport argparse # 用来解析命令行参数 import timeprint("测试时间 : ", time.strftime("%b %d %Y %H:%M:%S", time.gmtime(time.time())))print("************开始测试啦! 祈祷不出错!**************")# 需要测试的测试语句集合test_examples = [ "aaaaaaa", "bbbbbbb", "ccccccc"]dataMap = {"test": test_examples}parser = argparse.ArgumentParser()parser.add_argument("-d", default="60s", help="duration time", dest="duration_time") #解析命令行参数,控制测试时间args = parser.parse_args()print("每条语句测试时间 : ", args.duration_time)vus = ["10", "20", "30", "40"] # 并发数集合 ,分别测试并发数为10,20,30,40的场景cols_name = ["1-avg/ms", "1-rps/s", "10-avg/ms", "10-rps/s","20-avg/ms", "20-rps/s","50-avg/ms", "50-rps/s"] # excel的列名# 循环测试,可以将多个需要测试的语句集合放入到dataMap中for (name, data) in dataMap.items():  print("当前测试的项目为 :", name)        res = OrderedDict()        res["test_examples"] = [] for n in cols_name:                res[n] = []        df = pd.DataFrame(res) excel_name = name + ".xlsx" df.to_excel(excel_name, index=False) for query in data: print("当前测试语句为 :", query)                origin = pd.read_excel(excel_name) with alive_bar(len(vus)) as bar: temp_dict = {} temp_dict["test_examples"] = query for vu in vus: keyRps = vu + "-rps/s" keyTime = vu + "-avg/ms" MyVar="MyVar=" + query #通过Popen执行k6脚本,并且捕获它的标准输出                                process = subprocess.Popen(["k6", "run", "--quiet", "script.js", "--env", MyVar, "--vus", vu, "--duration", args.duration_time], stdout=subprocess.PIPE, stderr=subprocess.PIPE)                                result = process.stdout.read()                                temp = result.split() temp_dict[keyTime] = temp[0].decode(); temp_dict[keyRps] = temp[1].decode(); print("并发:", vu, temp[0].decode(), temp[1].decode()) bar() #将脚本输出写到excel save_data = origin.append(temp_dict, ignore_index=True) save_data.to_excel(excel_name, index=False)

执行此Python脚本,可以得到类似以下输出:

1、k6官网文档链接:https://k6.io/docs/

2、k6安装链接:https://k6.io/docs/get-started/installation/

号外

7月7日,华为开发者大会2023 ( Cloud )将拉开帷幕,并将在国内30多个城市、海外10多个国家开设分会场,诚邀您参加这场不容错过的年度开发者盛会,让我们一起开启探索之旅!

我们将携手开发者、客户、合作伙伴,为您呈现华为云系列产品服务与丰富的创新实践,并与您探讨AI、大数据、数据库、PaaS、aPaaS、媒体服务、云原生、安全、物联网、区块链、开源等技术话题,展开全面深入的交流。

大会将汇聚全球科学家、行业领袖、技术专家、社区大咖,开设200多场开发者专题活动,为全球开发者提供面对面交流与合作的机会,共同探讨技术创新和业务发展。

大会官网:https://developer.huaweicloud.com/HDC.Cloud2023.html

参会购票:https://www.vmall.com/product/10086352254099.html?cid= 211761

点击参与开发者社区活动,观赏技术大咖秀、玩转技术梦工厂,有机会赢取4000元开发者礼包!

欢迎关注“华为云开发者联盟”公众号,获取大会议程、精彩活动和前沿干货。

点击关注,第一时间了解华为云新鲜技术~

标签:

最新
  • 基于k6和python进行自动化性能测试

    摘要:在性能测试中,达到相应的性能指标对于一个软件来说十分重要,在

  • 箱体理论什么意思(箱体理论的判断方式是什么)

    箱体理论什么意思(箱体理论的判断方式是什么),一起来了解下吧。箱

  • ASML 副总裁:几乎不可能建立全自主芯片产业链 全球百事通

    光刻机巨头ASML执行副总裁兼商务总监ChristopheFouquet表示,全球半导

  • c反应蛋白高说明什么新冠(c反应蛋白高说明什么)-每日视讯

    1、CRP,C-反应蛋白,就感染而言,是间接反映细菌感染存在的较为敏感和

  • 世界动态:从“臭水沟”到“桃花源”——重庆九龙坡区桃花溪生态环境综合治理观察

    原标题:从“臭水沟”到“桃花源”——重庆九龙坡区桃花溪生态环境综合

  • 房产证上会有抵押状况吗 当前报道

    房产证上会不会有抵押状况一、有的房产证上写着抵押事项,一眼就能看出

  • 全球关注:建业地产全面停止境外债务支付,将全力保交付、保经营

    6月23日晚间,建业地产(HK00832,股价0 128港元,市值3 89亿港元)发

  • 环球今热点:推动品牌建设上台阶

    推动品牌建设上台阶

  • 2023年全国草原普法宣传月活动在肃南启动

    每日甘肃网肃南讯(新甘肃·甘肃日报记者侯洪建)6月20日,以“依法保

  • 苹果扩大的自修计划 iPhone14也可以了

    苹果公司正在扩大其自助维修计划,以涵盖其更多的最新设备,并在此过程

  • 中国天眼FAST又发现新天体 填补脉冲星演化缺失一环_天天亮点

    该成果艺术想象图。国家天文台供图人民网北京6月21日电(记者赵竹青)

  • 新乡万和城(新乡万和城什么时候开始动工

    新乡万和城何时交房 近日有网友反映新乡市万和城二期截至目前已烂尾十

  • 每日速看!湖南发布首批纺织行业新模式新业态典型案例 充分发挥“三品”标杆带动效应

    红网时刻新闻6月23日讯(记者胡冲通讯员袁亚)记者从省工信厅获悉,近

  • 天天快播:鲍威尔最新发声,释放重磅信号!油价突然崩了

    美联储主席鲍威尔表示年内加息两次是适当的,但明年可能降息,并认为美

  • 人类并非地球唯一的文明,在人类之前,地球上还有更高级的文明?

    科学家们发现了一些高智慧生物的化石,他们由此推测或许人类并不是地球

  • 【世界快播报】“国际旅行健康证明”30日起下线

    “国际旅行健康证明”30日起下线请注意,不要与“国际旅行健康证”混淆

  • 旅游
    • 天天快消息!马航370飞机找到了吗?马航370为什么不找了?

    • 全球简讯:多家村镇银行下调存款利率

    • 七位基金经理解读白酒“大反攻”:估值底部信号已现_世界通讯

    • 美国得州遭龙卷风袭击 造成至少三人死亡数十人受伤 世界热讯