Locust快速入门

Locust,基于Python的性能测试工具。

示例locustfile.py

下面是一个简单的locustfile.py小示例:

from locust import HttpLocust, TaskSet

def login(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)

class WebsiteUser(HttpLocust):
    task_set = UserBehavior
    min_wait = 5000
    max_wait = 9000

这里我们定义了一些带一个参数(Locust类实例)正常Python回调的Locust任务。这些任务在task属性中 TaskSet类被聚集。接下来,我们有一个代表一个用户的HttpLocust类,这里我们定义多久一个模拟用户应该等待在执行任务之间,同时TaskSet类应该定义用户行为.python类TaskSet <locust.core.TaskSet>可以被嵌入。

HttpLocust类从Locust类中继承,它有一个用于发送HTTP请求的HttpSession属性在客户端属性中。

另外一种方式,我们可以使用另外一种更简洁的方法声明任务,就是使用@task声明。下面的代码和上面的代码一致:

from locust import HttpLocust, TaskSet, task

class UserBehavior(TaskSet):
    def on_start(self):
        """ on_start is called when a Locust start before any task is scheduled """
        self.login()

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

    @task(2)
    def index(self):
        self.client.get("/")

    @task(1)
    def profile(self):
        self.client.get("/profile")

class WebsiteUser(HttpLocust):
    task_set = UserBehavior
    min_wait = 5000
    max_wait = 9000

Locust类(在子类中也叫HttpLocust类)可以指定针对每一个模拟用户在执行任务之间设置最小和最大的等待时间(min_wait和max_wait),像用户行为一样。

启动Locust

为了运行上面的Locust文件,如果文件被命名为locustfile.py并保存在当前目录,我们可以直接运行:

locust --host=http://example.com

如果Locust文件在子文件夹或命名与locustfile.py不一致时,可以通过参数-f:

locust -f locust_files/my_locust_file.py --host=http://example.com

运行Locust的分布式多线程,我们应该启动master通过参数--master:

locust -f locust_files/my_locust_file.py --master --host=http://example.com

接下来我们可以启动slave线程:

locust -f locust_files/my_locust_file.py --slave --host=http://example.com

如果我们想运行Locust在多台机器,在启动slaves时,我们应该指定master地址(这不是必须的,当运行Locust分布式在同一台机器时,master的默认地址是127.0.0.1):

locust -f locust_files/my_locust_file.py --slave --master-host=192.168.0.100 --host=http://example.com

查看所有的选项,输入:

locust  --help

打开Locust的Web界面

一旦你通过上面的命令启动了Locust,你应该打开浏览器并输入http://127.0.0.1:8089(如果你是在本机运行的Locust)。接下来,你应该可以看到下面的页面:

UI
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,924评论 25 708
  • Locust文件就是一般的Python文件。唯一的需求就是它至少需要一个继承于Locust的类. Locust类 ...
    Yuan_Jie阅读 4,056评论 0 7
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,845评论 18 139
  • Locust是什么? Locust 是一个开源负载测试工具。使用 Python 代码定义用户行为,也可以仿真百万个...
    zychen143阅读 7,185评论 1 2
  • 傍晚,过街天桥下边常会冒出两个旧书摊。就在总去解决晚饭的那家小馆旁边。 只蹲下翻看过一次,多是盗版旧书,封皮内页上...
    波泊佛阅读 269评论 0 1