后端工程师压力测试、并发测试实践

文章介绍了单接口压测的重要性,包括了解接口承载能力、发现性能瓶颈,并提到了压测结果可能受到的外界因素如本机句柄数、DNS解析速度等。文中推荐了Jmeter、ab和Apipost等压测工具,特别强调Apipost的便捷性,并提供了压测流程的详细步骤。同时,强调了选择合适并发数和监控响应能力在压测中的关键作用。
摘要由CSDN通过智能技术生成

压测背景

单接口压测是为了能够在开发阶段对单个接口进行性能测试,快速了解接口的承载能力、发现性能瓶颈,在开发早期就能发现问题,消除性能风险。

作为一名优秀的后端工程师,在交付线上环境前,对自己的每一个接口进行简单的性能检测,是一种良好的职业习惯。

另外,当业务在生产环境遇到实际接口请求瓶颈时,通过模拟真实的并发环境,也是一种快速寻找问题的方式。

压测结果的影响因素

高并发结果很容易受外界因素影响,压测时需要尽量减少外界因素影响。

影响压测结果外界因素有本机句柄数限制,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、压测任务完成后,页面展示压测结果,完成压测。

 压测结果计算方式

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值