0
点赞
收藏
分享

微信扫一扫

Locust学习记录一

小飞侠熙熙 2022-02-12 阅读 115

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 教程丨阿西河

举报

相关推荐

locust编写

locust 使用

MySQL学习记录一

Python学习记录 一

0 条评论