写点什么

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

  • 2023-02-10
    北京
  • 本文字数:1030 字

    阅读完需:约 3 分钟

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

压测背景

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

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

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

压测结果的影响因素

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

影响压测结果外界因素有本机句柄数限制,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 语言的压测引擎(已开源:https://github.com/Apipost-Team/runnerGo),比较较好的支持单机高并发压测。但不足的是目前仅支持 http/https 协议,对 websocket、grpc 等协议尚未支持。

本文仅简单介绍基于 http/https 协议的压测实践,出于便捷性考虑,我们采用 Apipost 的压测模块。

压测流程

1、压测模块位于 API 调试模块下,在进行接口调试时可以看到,如图所示:

2、在输入被压测的 URL 后,在压测 tab 下,填写并发数和轮次;

3、点击【开始压测】按钮,页面展示【压测中...】状态;

4、压测任务完成后,页面展示压测结果,完成压测。

压测结果计算方式


用户头像

还未添加个人签名 2022-04-10 加入

还未添加个人简介

评论

发布
暂无评论
压力测试、并发测试实践,后端工程师必看_Jmeter_爱研究代码的极客人_InfoQ写作社区