【性能学习】Locust

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


locustUI.png

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

对比图.png

得分项:单机并发能力,Python,开源免费

掉分项:不支持资源监控,报告异常简单

纸上得来终觉浅,始知此事须躬行。

  1. 安装(和一切python第三方包安装方式一致)
    $ pip install locustio

  2. 编写一个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
复制代码

 

  1. 在存放文件的目录下以命令行方式运行以上py文件
    $locust -f basic.py
    可见类似以下的画面:
basic.png

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

LocustWeb.png
  • 第一个输入框:想并发的人数
  • 第二个输入框:虚拟用户初始化的比例
    比如上图中的意思就是想测试1000个虚拟用户对系统的压测,刚开始的时候是以10人/秒的速度开始递增到1000人。

点击“”Start Swarming“”后你就可以开始压测你想压测的系统了。

  1. 查看执行结果(上一步点击后页面会自动刷新到结果页面,但是需要手动停止)
statistics.png

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

locustcharts.png

目前只有每秒请求数,平均响应时间,用户的增长曲线 三个图可看。

当然,你也通过 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。

Authors.png


作者:CC先生之简书
链接:https://www.jianshu.com/p/292c2001ff27
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
posted @   gtea  阅读(225)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示