locust使用

安装

locust 官方介绍https://locust.io/

① 可以直接通过pip安装,安装命令

pip install locustio

可能出现的问题:可能出现gcc编译失败等问题,可以先pip安装zmq

② 通过源码安装

备注:在gcc 4.8+以上版本使用源码安装。下载locust-master代码

安装顺序:

python setup.py build 

python setup.py install

如果locust有依赖安装失败,可用pip安装缺失依赖。例:pip安装zmq,pip install zmq

验证是否安装成功:locust --help

③ 安装的Q&A

· 注意locust 的版本和python版本是否匹配,可以查看locust的setup.py 中的说明。目前已知0.11 /0.9支持python2.7

· locust可以启动压测脚本,web页面不能操作、没有趋势图。排查flask是否安装成功:import flask

启动方式

单进程运行

no_web方式

可以使用Locust的单进程no_web运行模式进行本地脚本调试。启动方式:locust -f test.py --no-web -c 1

参数讲解:-f 启动的文件, --no-web 非web方式启动 -c 指定并发数 -n 总执行次数

web方式

如果采用web形式,,则通常情况下无需指定其它额外参数,Locust默认采用8089端口启动web。如果使用其他端口,需要使用如下参数进行指定

-P, --port:指定web端口,默认为8089

locust -f test.py  -P 8098 --web-host=127.0.0.1 --only-summary

启动的时候注意指定--web-host,防止出现绑定异常

按照如上方式启动后,case并没有执行,通过暴露的web服务127.0.0.1:8098 访问webUI,配置参数

Number of users to simulate: 设置并发用户数,对应中no_web模式的-c, --clients参数;

Hatch rate (users spawned/second): 启动虚拟用户的速率,对应着no_web模式的-r, --hatch-rate参数。

多进程分布式运行

当并发压力要求较高时,就需要用到Locust的多进程分布式运行模式。从字面意思上看,第一反应就是多台压力机同时运行,每台压力机分担负载一部分的压力生成。的确,Locust支持任意多台压力机(一主多从)的分布式运行模式,但这里说到的多进程分布式运行模式还有另外一种情况,就是在同一台压力机上开启多个slave的情况。这是因为当前阶段大多数计算机的CPU都是多处理器(multiple processor cores),单进程运行模式下只能用到一个处理器的能力,而通过在一台压力机上运行多个slave,就能调用多个处理器的能力了。比较好的做法是,如果一台压力机有N个处理器内核,那么就在这台压力机上启动一个master,N个slave。当然,我们也可以启动N的倍数个slave,但是根据试验数据,效果跟N个差不多,因此只需要启动N个slave即可。

master启动方式

locust -f test.py  -P 8098 --web-host=10.10.10.10  --master : 没有特殊指定--master-bind-port默认为5557

slave启动方式

locust -f test.py --slave --master-host=10.10.10.10 :没有特殊指定 --master-port 默认为5557

master和slave都启动完毕后,就可以在浏览器中通过http://locust_machine_ip:8089进入Locust的Web管理页面了。使用方式跟单进程web形式完全相同,只是此时是通过多进程负载来生成并发压力,在web管理界面中也能看到实际的slave数量。

locust相关

Locust

可以理解为用户,用户的行为由taskset指定。大家可以基于locust基类实现继承类的用户,比如:httpLocust就是基于Locust派生而来,并指定了它的client = httpSession

属性介绍:

max_wait= 1000  : 执行task最大等待时间

min_wait= 1000 :执行task最小等待时间

task_set= None : locust执行的task类

weight= 10:locust被挑选的权重

HttpLocust

基于Locust派生的http user,底层的client为httpSession(基于python.requests实现)。HTTP的类压测可直接用HttpLocust

TaskSet

Locust User执行的task列表,属性解释:

max_wait= None :task最大执行间隔,默认不设置,如果设置了将覆盖locust中的max_wait

min_wait= None:task最小执行间隔,默认不设置,如果设置了将覆盖locust中的max_wait

tasks = [] :task列表

on_start:方法,执行tasks之前执行的方法,只执行一次,可以作为初始化使用

如何写TaskSet

① 通过tasks指定执行权重

from locust import HttpLocust, TaskSet

deflogin(l):

    l.client.post("/login", {"username":"ellen_key", "password":"education"})

def index(l):

    l.client.get("/")

def profile(l):

    l.client.get("/profile")

class UserBehavior(TaskSet):

    tasks ={index: 2, profile: 1}#注意这一行,后面数字为执行比例

    def on_start(self):

        login(self)

② 通过装饰器权重、执行顺序

from locust import HttpLocust, TaskSet

def login(l):

    l.client.post("/login", {"username":"ellen_key", "password":"education"})

class UserBehavior(TaskSet):

    def on_start(self):

        login(self)

@task(2) 

@seq_task(1)

def index(self):

    self.client.get("/")

@task(1)

@seq_task(2)

def profile(l):

    l.client.get("/profile")

@task 是权重装饰器,index:profile的执行比例是2:1

@seq_task为顺序装饰器,tasks按照如上先index、后profile的顺序进行

Event hooks

为了进行数据统计,用户可以自己定义成功、失败、异常相关的事件统计。目前支持的可用hooks见https://docs.locust.io/en/stable/api.html#available-hooks

以request_success 为例进行说明如何使用

request_success= <locust.events.EventHook object>

request_success is fired when a request is completed successfully.

Listeners should take the following arguments:

request_type: Request type method used

name: Path to the URL that was called (or override name if it was used in the call to the client)

response_time: Response time in milliseconds

response_length: Content-length of the response

当你认为task中某个请求成功,可以直接通过events.request_success.fire进行记录,参数即为如上描述。

由于Locust类和TaskSet类有多种setup/teardown相互依赖,下面是这些类的执行顺序,方便理解:

Locust setup

TaskSet setup

TaskSet on_start

TaskSet tasks…

TaskSet on_stop

TaskSet teardown

Locust teardown

附录

深入浅出开源性能测试工具 Locust    https://debugtalk.com/post/head-first-locust-user-guide/ 

locust官方文档https://docs.locust.io/en/stable/

gevent 猴子补丁http://www.gevent.org/api/gevent.monkey.html

dumeter locust的帮助文档Locust测试

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,406评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,732评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,711评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,380评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,432评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,301评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,145评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,008评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,443评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,649评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,795评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,501评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,119评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,731评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,865评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,899评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,724评论 2 354

推荐阅读更多精彩内容

  • 参考链接:https://www.cnblogs.com/imyalost/p/9758189.html Locu...
    爱读书的夏夏阅读 1,014评论 5 1
  • Locust性能测试1-环境准备与基本使用 前言 提到性能测试,大部分小伙伴想到的就是LR和jmeter这种工具,...
    Alano_Ones阅读 342评论 0 0
  • 一、安装Locust 安装Locust之前先安装的库: gevent库:第三方库,gevent为python提供了...
    huxt阅读 852评论 0 0
  • 官方文档https://docs.locust.io/en/latest/writing-a-locustfile...
    心悦飞飞阅读 1,029评论 0 1
  • Locust文件就是一般的Python文件。唯一的需求就是它至少需要一个继承于Locust的类. Locust类 ...
    Yuan_Jie阅读 4,036评论 0 7