发现一款后端程序员必备的压测工具,十分钟就能上手,yyds
压测背景
单接口压测是为了能够在开发阶段对单个接口进行性能测试,快速了解接口的承载能力、发现性能瓶颈,在开发早期就能发现问题,消除性能风险。
作为一名优秀的后端工程师,在交付线上环境前,对自己的每一个接口进行简单的性能检测,是一种良好的职业习惯。
另外,当业务在生产环境遇到实际接口请求瓶颈时,通过模拟真实的并发环境,也是一种快速寻找问题的方式。
压测结果的影响因素
高并发结果很容易受外界因素影响,压测时需要尽量减少外界因素影响。
影响压测结果外界因素有本机句柄数限制,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上线了单接口一键并发功能。据官方说法:底层采用了自研的基于Golang语言的压测引擎
已开源:http://github.com/Apipost-Team/runnerGo
能较好的支持单机高并发压测。目前支持http/https协议,对websocket、grpc等协议尚未支持。
本文简单介绍基于http/https协议的压测实践,出于便捷性考虑,这里采用 Apipost 的压测模块。
压测流程
1、压测模块位于API调试模块下,在进行接口调试时可以看到,如图所示:
2、在输入被压测的URL后,在压测tab下,填写并发数和轮次;
3、点击【开始压测】按钮,页面展示【压测中...】状态;
4、压测任务完成后,页面展示压测结果,完成压测。
压测结果计算方式:
- 发现一款后端程序员必备的压测工具,十分钟就能上手,yyds
- 银行外包996,骑驴找马要跳槽
- 外包四年太差劲,幡然醒悟要跳槽
- 装了我这 10 个 IDEA 神级插件后,同事也开始情不自禁的嘚瑟了
- JetBrains再出手,这次要干翻 VS Code了????
- 我的第一个,10万
- GitHub 官宣:弃用 trending 热榜,开发者炸锅了
- 大吃一惊!GitHub 30天后弃用Trending热榜!
- WindTerm:新一代开源免费的终端工具,GitHub星标6.6k ,太酷了!
- 网上接单挣了 10000 元后的感触
- 别再用 System.currentTimeMillis 统计耗时了,太 Low,试试 Spring Boot 源码在用的 StopWatch吧,够优雅!
- 别再用 System.currentTimeMillis 统计耗时了,太LOW,这个工具类好用到爆!
- 在IDEA里下个五子棋不过分吧?
- 在IDEA里下五子棋不过分吧?
- 好用到爆!GitHub 星标 32.5k 的命令行软件管理神器,功能真心强大!
- 终于,梦想实现了
- 我扔进垃圾桶的第一本Java书...
- 解放双手!推荐一款 GitHub 星标 8.2k 的命令行软件管理器,非常酷炫!
- 再见收费的TeamViewer,推荐一款不限速的国产远程控制软件
- 我的母亲