news 2026/6/15 9:23:02

Locust:可能是一款最被低估的压测工具

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Locust:可能是一款最被低估的压测工具

01 Locust介绍

开源性能测试工具https://www.locust.io/,基于Python的性能压测工具,使用Python代码来定义用户行为,模拟百万计的并发用户访问。每个测试用户的行为由您定义,并且通过Web UI实时监控聚集过程。

压力发生器作为性能测试工具的核心部分,两个核心要点有:一是真实模拟用户操作,二是模拟有效并发

模拟用户请求操作上:

只要我们能采用Python编写对应的请求客户端,就能方便地采用Locust实现压力测试;

模拟有效并发方面:

Locust完全基于事件,使用gevent (协程)提供的非阻塞IO和coroutine来实现网络层的并发请求,避免了系统级资源调度,大幅提高了性能,因此即使是单台压力机也能产生数千并发请求数。

主流压测工具对比:

02 基本原理

主要的三个类:HttpLocust, TaskSet, task

Locust类代表一群蝗虫,而每一只蝗虫就是一个类的实例,TaskSet类则可代表蝗虫的大脑,即实际业务场景测试对应的任务集。

1、Locust类

继承于Locust的类代表一个用户,Locust会为每一个模拟用户生成一个locust类实例。

在Locust类中,还有几个属性需要关注下:

2、TaskSet类

TaskSet定义任务信息,是定义待测试的任务代码集。每一个Locust类中包含一个指向TaskSet的task_set属性设置。测试任务开始后,每个 Locust 用户会从 TaskSet 中随机挑选一个任务执行,然后随机等待 HttpLocust 类中定义的 min_wait和 max_wait 之间的一段时间,执行下一个任务。

3、task

通过@task()装饰的方法为一个事务。方法的参数用于指定该行为的执行权重。参数越大每次被虚拟用户执行的概率越高。如果不设置默认为1。

tasks = {classname:2} 表示每个用户执行 classname 的频率是2

4、执行原理

测试开始后,每个虚拟用户(Locust实例)的运行逻辑都会遵循如下规律:

先执行WebsiteTasks中的on_start(有则执行,只执行一次),作为初始化;

从WebsiteTasks中随机挑选(如果定义了任务间的权重关系,那么就是按照权重关系随机挑选)一个任务执行;

根据Locust类中min_wait和max_wait定义的间隔时间范围(如果TaskSet类中也定义了min_wait或者max_wait,以TaskSet中的优先),在时间范围中随机取一个值,休眠等待;

重复2~3步骤,直至测试任务终止。

03 实例

实例

V1.1 有些小改动,原理类似,QuickStartUser继承HttpUser,定义用户行为集。

index() 、search() 方法访问百度首页,用@task() 装饰该方法为一个任务,1表示一个Locust实例被挑选执行的权重,数值越大,执行频率越高。

运行结果:

启动性能:

locust -f demo_pt.py # --host=https://www.baidu.com -f, --locustfile:指定执行的Locust脚本文件

AI写代码bash

访问:http://127.0.0.1:8089

Number of users to simulate:设置模拟用户数

Hatch rate (users spawned/second) :每秒产生(启动)的用户数。

展示结果:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 14:28:44

构建高效的本地 LLM 管道:从 Windows 环境配置到 RAG 与 QLoRA 微调

构建高效的本地 LLM 管道:从 Windows 环境配置到 RAG 与 QLoRA 微调手册(2025 版) 第一部分:基础环境篇——消费级 GPU 下的高效 LLM 推理框架搭建 目标:针对 Windows 用户解决 CUDA 兼容性、Python 环境冲突及 WSL2 迁移痛点,实现 1 小时内部署首个量化 LLM,支持 12G…

作者头像 李华
网站建设 2026/6/15 2:21:41

比特币矿企转型AI计算,股票应声大涨

比特币矿企股票随另一家公司拥抱人工智能热潮而飙升 加密货币挖矿公司的股票在周一飙升,与此同时,比特币和其他加密货币因市场对美国和中国可能至少部分解决贸易争端的乐观情绪而反弹。 嘉楠科技在周一下午收盘时上涨约28%。比特币矿企CleanSpark在周一宣…

作者头像 李华
网站建设 2026/6/15 2:18:40

好用的漏洞库

cnnvd 太难用了,搜了一下长亭、aliyun 的漏洞库排名比较高 体感 aliyun 的 UI 要好一点,qax 会多一点古早漏洞 阿里云漏洞库 漏洞库 - CT Stack 安全社区 奇安信威胁情报中心 直接爬 cnnvd 也不难,那个前端是一个 SPA 的应用,初…

作者头像 李华
网站建设 2026/6/15 12:24:45

Python语言编程导论第四章 流程控制

内容提要 概述 条件语句 循环语句 跳转语句 综合实例 一、概述 之前编写的程序都是顺序结构的,即依次执行程序中的每条语句。 但实际的程序并非如此简单,经常要用到条件判断或反复执行某一个程序段,这就要用到条件语句和循环语句。 本…

作者头像 李华
网站建设 2026/6/15 10:25:57

无需完整Anaconda:用Miniconda快速部署PyTorch GPU环境

无需完整Anaconda:用Miniconda快速部署PyTorch GPU环境 在现代AI开发中,时间就是生产力。当你准备开始一个深度学习项目时,最不想花几个小时折腾的,就是环境配置——尤其是面对那些动辄3GB以上的Python发行版,装完才发…

作者头像 李华