【性能学习】Locust
Locust(俗称 蝗虫), 一个轻量级的开源压测工具,用Python编写。

网上已有不少的人总结了Locust与其余几个性能测试翘楚之间的差异。(灯光师,麻烦往第三位佳丽这边打亮一点)

得分项:单机并发能力,Python,开源免费
掉分项:不支持资源监控,报告异常简单
纸上得来终觉浅,始知此事须躬行。
-
安装(和一切python第三方包安装方式一致)
$ pip install locustio -
编写一个Locust 文件(保存为 一个py文件,取任意名,比如basic.py)
1 from locust import HttpLocust, TaskSet, task 2 3 def index(l): 4 l.client.get("/") 5 6 def stats(l): 7 l.client.get("/stats/requests") 8 9 class UserTasks(TaskSet): 10 # 列出需要测试的任务形式一 11 tasks = [index, stats] 12 # 列出需要测试的任务形式二 13 @task 14 def page404(self): 15 self.client.get("/does_not_exist") 16 17 class WebsiteUser(HttpLocust): 18 host = "http://127.0.0.1:8089" 19 min_wait = 2000 20 max_wait = 5000 21 task_set = UserTasks
- 在存放文件的目录下以命令行方式运行以上py文件
$locust -f basic.py
可见类似以下的画面:

4.打开浏览器,输入地址:http://127.0.0.1:8089,开启Locust Web操作页面

- 第一个输入框:想并发的人数
- 第二个输入框:虚拟用户初始化的比例
比如上图中的意思就是想测试1000个虚拟用户对系统的压测,刚开始的时候是以10人/秒的速度开始递增到1000人。
点击“”Start Swarming“”后你就可以开始压测你想压测的系统了。
- 查看执行结果(上一步点击后页面会自动刷新到结果页面,但是需要手动停止)

也可以切换到Charts看图形化结果

目前只有每秒请求数,平均响应时间,用户的增长曲线 三个图可看。
当然,你也通过 Download Data链接下载刚才的结果。
再回到刚开始的问题,什么是Locust呢?
locust是一个易于使用的,分布式的,用户负载测试工具。用于web站点(或其他系统)的负载测试,然后算出系统能够处理多少并发用户。
locust的思想是:在测试期间,一大群"蝗虫"会攻击你的网站,每一个"蝗虫"的行为都是由你自己定义的,同时,可以在一个web界面上实时的监控这群进程。这会帮助你更好的"进行战斗",在真正的用户进入之前,就找出代码中的瓶颈。
locust完全是事件驱动的,因此它能够在单机支持数以千计的并发用户,相比许多其他的基于事件的应用,locust不使用回调函数。它使用轻量进程---gevent。每一个访问你的网站的locust实际上都在它自己的进程内部运行(准确地说,是greenlet),也就是我们通常说的协程。这允许你在不使用带回调函数的复杂代码的情形下,使用python写出非常具有表现力的脚本。
目前Locust支持的版本有:
Python 2.7, 3.3, 3.4, 3.5, and 3.6
Locust的高阶应用之后再慢慢探索。So far so good.
比如,查看多目录的网页,查看需要登录后才能操作的网页,分布式的压测等。
能在这么短的时间内就搭建好一个压测工具,果然很Pythonic,希望以下的几位 小哥哥为代表的大神们更加努力,我们能更早用上一个有良好报告的Locust。

作者:CC先生之简书
链接:https://www.jianshu.com/p/292c2001ff27
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!