压测背景
单接口压测是为了能够在开发阶段对单个接口进行性能测试,快速了解接口的承载能力、发现性能瓶颈,在开发早期就能发现问题,消除性能风险。
作为一名优秀的后端工程师,在交付线上环境前,对自己的每一个接口进行简单的性能检测,是一种良好的职业习惯。
另外,当业务在生产环境遇到实际接口请求瓶颈时,通过模拟真实的并发环境,也是一种快速寻找问题的方式。
压测结果的影响因素
高并发结果很容易受外界因素影响,压测时需要尽量减少外界因素影响。
影响压测结果外界因素有本机句柄数限制,dns解析速度,网络质量,服务端连接数限制等等。例如使用1w并发,很容易出现超过本机最大句柄数限制(一般最大限制1024),超过句柄数限制的请求会因为句柄数受限导致连接失败。
因此选择合适并发数对测试接口性能非常重要,并非并发数越大越好。
实际实践中建议并发数先在10,100,500,1000左右分别测试下,如果失败率小于1%,再考虑逐步增加并发数量。只有增加并发每秒请求数量能持续增加才是健康的使用方式。当并发数增加到一定数量后,接口响应能力不再增加或者错误数变高,这时候再增加并发量是无效的。
压测工具
1、Jmeter
Jmeter是apache公司基于java开发的一款开源压力测试工具,体积小,功能全,支持http、https、websocket、grpc等协议的并发压测。但缺点在于比较消耗单机性能,一般用于分布式压测或作为压测引擎使用。另外如果只想针对一个接口进行简单测试,需要较深的操作路径,使用起来较为繁琐。
2、ab
ab是apache自带的压力测试工具。ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行压力测试。比如nginx、tomcat、IIS等。
但唯一不足的是,ab基本是命令行执行,如果一个接口需要输入较复杂的请求参数,操作起来会比较繁琐。
3、Apipost
自7.0.12版本起,Apipost上线了单接口一键并发功能。
下载:下载中心-Apipost-中文版接口调试与文档管理工具
该功能底层采用了自研的基于Golang语言的压测引擎(已开源:https://github.com/Apipost-Team/runnerGo),比较好的支持单机高并发压测。目前支持http/https协议,对websocket、grpc等协议尚未支持。
本文仅简单介绍基于http/https协议的压测实践,出于便捷性考虑,我们采用 Apipost 的压测模块。
压测流程
1、压测模块位于API调试模块下,在进行接口调试时可以看到,如图所示:
2、在输入被压测的URL后,在压测tab下,填写并发数和轮次;
3、点击【开始压测】按钮,页面展示【压测中...】状态;
4、压测任务完成后,页面展示压测结果,完成压测。
压测结果计算方式