Locust是使用Python语言编写实现的开源性能测试工具,可以用来测试Web应用程序、API、数据库等各种应用程序的性能,使用起来简洁、轻量、高效,并发机制基于gevent协程,可以实现单机模拟生成较高的并发压力。中文意为:蝗虫,蝗虫过境,寸草不生。
它的主要思想:模拟一群用户将访问你的网站。每个用户的行为由你编写的python代码定义,同时可以从
Web界面中实时观察到用户的行为。
Lucust的主要特点包括:
性能测试通常需要有压力发生器,系统资源监控器,结果采集器,结果分析器等组件。
与jmeter类似,locust没有系统资源监控器
下面是locust与jemter,loadrunner的功能对比
locust的官网:https://www.locust.io/,项目地址:https://github.com/locustio/locust
2.1 导入所需的库和函数,如:
from locust import HttpUser, task, between
其中,HttpUser为基础用户类,task用于定义任务,between用于指定用户执行任务的时间间隔。
2.2 定义用户类:
class MyUser(HttpUser):wait_time = between(1, 3)@taskdef my_task(self):self.client.get("/path")
其中,wait_time指定用户执行任务之间的等待间隔,@task为任务定义装饰器,my_task为任务函数名称,self.client.get(“/path”)为具体的任务执行代码。
2.3. 运行Locust:
locust -f my_script.py
其中,-f参数指定要执行的脚本文件。
2.4. 在浏览器中访问Locust Web界面,如:
http://localhost:8089/
在界面中可以指定用户数、用户增长速率、任务权重等参数,并实时查看测试结果。
如下为一个简单实例,其中on_start为对locust内置方法的重写,另外还有on_stop方法。
from locust import HttpUser, TaskSet, taskclass WebsiteTasks(TaskSet):def on_start(self): # 进行初始化的工作,每个Locust用户开始做的第一件事payload = {"username": "XXXX","password": "123456",}header = {"User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36",}self.client.post("/login", data=payload,headers=header) # self.client属性使用Python request库的所有方法,调用和使用方法和requests完全一致;@task(2) # 通过@task()装饰的方法为一个事务,方法的参数用于指定该行为的执行权重,参数越大每次被虚拟用户执行的概率越高,默认为1def index(self):self.client.get("/")@task(1)def about(self):self.client.get("/about/")class WebsiteUser(HttpUser):host = "https://github.com/" # 被测系统的host,在终端中启动locust时没有指定--host参数时才会用到tasks = [WebsiteTasks] # TaskSet类,该类定义用户任务信息,必填。这里就是WebsiteTasks类名,因为该类继承TaskSet;min_wait = 3000 # 每个用户执行两个任务间隔时间的上下限(毫秒),具体数值在上下限中随机取值,若不指定默认间隔时间固定为1秒max_wait = 10000
1、脚本调试命令行:
locust -f locustfile.py --headless -u 1 -r 1 –t 30s
2、在Terminal以如下命令启动locust,通常情况下不需额外指定其他参数:
locust -f locustfile.py
3、Locust默认采用8089端口启动web,如果要使用其它端口,就可以使用如下参数进行指定:
locust -f locustfile.py –web-port 8089
4、–host用来指定测试主机地址
locust -f locustfile.py --host=http://example.com