Locust是什么?
Locust是一个比较容易上手的分布式用户负载测试工具
它旨在对网站(或其他系统)进行负载测试,并确定系统可以处理多少个并发用户,Jmeter也可以处理这种场景,但是个人感觉Jmeter在这方便做的不如Locust专业
Locust在英文中时【蝗虫】的意思:
当然实现是可以用Locust定义每个蝗虫(或测试用户)的行为,并且通过webUi 实时监视围攻过程
这将帮助您在项目上线之前测试并确定项目的瓶颈
Locust可以让测试工程师对开发人员和项目经理的回复更专业:
可以想象一下,当项目及经理或领导问你这个项目的性能如何,可以承受多少压力的时候;
你的回答说这个项目在2314人同时访问,超过就会挂掉/宕机/出错等,当在1834人同时访问的时候,会变慢;具体访问时间的视图XXX
这样的回答是不是显得自己专业能力更高?
Locust的运行原理
Locust的运行原理是完全基于事件运行的,因此可以在一台计算机上支持数千个并发用户;
与许多其他基于事件的应用程序相比,它不使用回调(比如Nodesjs就是属于回调,Locust不使用这种逻辑)
相反,他通过gevent【协程】使用轻量级进程。测试您站点的每个蝗虫实际上都在其自己的进程中运行(正确的说,是Greenlet)
这可以让您写python代码的时候更加简单,而不会进入类似JS的那种回调地域
Locust的特征
用python编写测试方案
1.不需要在UI界面傻乎乎的点击,只需正常的写写代码就可以了
2.Locust基于协程而不是回调,这样会让您的代码类似于正常的python阻塞代码那样同步执行
分布式&扩展
1.支持模拟数十万的用户行为
2.Locust支持分布在多台计算机上运行负载测试(可以多台机器并行开搞)
3.由于基于事件,因此即使一个蝗虫节点也可以在单个过程中处理数千万个用户
4.不过即使您模拟了这么多用户,也并非所有人都是这种频率的使用您的系统,通常,用户会有思考的时候,会想一想下一步该怎么做
注意!【每秒请求数】不等于【在线用户数】
统计结果基于Web界面
1.Locust有一个简单的用户界面,可实时显示相关的测试详细信息
2.统计结果界面基于网页的,而网页天生是跨平台的,所以Locust是跨平台且易于扩展的
可以测试任何【网页】【应用】【系统】
1.即使Locust是面向Web的,它页可以测试几乎所有项目
2.只需要python编写想要的测试方法,然后放【蝗虫】去执行需要测试的项目就可以了
容易被入侵
1.Locust放出去的蝗虫很小,很容易被入侵,开发团队是一直打算保持这种状态的
2.时间I/O和协程的所有繁重工作都委托给gevent
Locust是完全基于python
http请求完全是基于requests库;
Locust支持http,https协议,还支持其他协议,webSocket等
只要采用python调用对应的库就可以了
http/https采用requests;
webSocket采用webSocket;
Locust的创作背景
Locust之所以创建,是因为左右对现有的性能测试解决方案不满意
Jmeter带有一个UI,很多人可能会认为这是一件好事,只需要会点点就好;
但是通过某些点击界面【编码】您的测试方案是一种PITA
其次,Jmeter是线程绑定的,这意味着对于每个模拟用户,都需要一个单独的线程,这也就导致,在一台计算机上模拟成千上万的用户进行测试时不可行的
另一方面,Tsung没有用Erlang编写的线程问题
它可以利用BEAM自身提供的轻量级工艺,并且可以愉快的扩展规模
但是在定义测试方案时,Tsung和Jmeter一样有限
它提供了基于XML的DSL来定义用户在测试时的行为方式(这种格式很Low,但是很直观)。完成后显示任何种类的图形和报告,都需要对测试生成的日志进行后处理,只有这样,您才能了解测试的进行方式
原文地址:Locust 教程丨阿西河