Locust 2.8 任务集 TaskSet

任务集

TaskSet

TaskSet是一个任务集合,里面所有的任务都是同时进行的,没有先后顺序,支持嵌套

class MyTaskSet1(TaskSet):

    # @task
    # 加了权重只后,运行率会更均匀,可能是locust的问题吧
    @task(1)
    def task1(self):
        self.client.get('/task1')


class MyTaskSet2(TaskSet):

    # @task
    @task(1)
    def task2(self):
        self.client.get('/task1')


class Play(HttpUser):
    tasks = [MyTaskSet1, MyTaskSet2]

理论上这两个 TaskSet 执行的数量应该是一样的但是并没有,加了 task 的权重只后是均分的,可能是 locust 没有权重的情况下任务分配的问题吧

还有一个需要注意的地方,这里100用户数,是同时被两个 TaskSet 消费的,也就是说每个用户会选择其一去执行它

image-20220328203824683

嵌套写法:

from locust import TaskSet, task, HttpUser, constant


class UserTask(TaskSet):
    @task
    class stay(TaskSet):
        @task
        def readBook(self):
            self.client.get('/readBook')

        @task
        def listenMusic(self):
            self.client.get('/listenMusic')
            # 退出当前任务集
            self.interrupt()

    @task
    def leave(self):
        self.client.get('/leave')


class User(HttpUser):
    tasks = [UserTask]
    wait_time = constant(2)

没有 interrupt() 方法的执行结果:

可以看到,在执行过第一轮之后,后续就不再执行 leave 了,只会运行 stay 中的任务

image-20220328202554257

有 interrupt() 方法的执行结果:

在足够长的运行时间下,可以看到每个任务的执行率都是相同的

image-20220328200757044

SequentialTaskSet

按顺序执行的任务集,此示例的执行顺序是 task1 -> task2 -> task3

跟 TaskSet 一样,是支持嵌套的,可以使用这个特性设计复杂的业务场景

class MyTaskSet(SequentialTaskSet):

    @task
    def task1(self):
        self.client.get('/task1')

    @task
    def task2(self):
        self.client.get('/task2')

    @task
    def task3(self):
        self.client.get('/task3')

class Play(HttpUser):
    tasks = [MyTaskSet]
    wait_time = constant(1)

执行结果:

任务分配的很均匀,而且始终保持 task1 -> task2 -> task3 这样的顺序执行

需要注意的是,我启动了100个用户,被 3 个 task 平均分配了

我们在设计性能测试场景的时候,一定要注意这个任务被每一个 task 平均分配的问题,很可能你分配的用户数量并不符合你预期并发量,这跟 jmeter 是有非常大差别的

image-20220328205335991

<think>好的,我需要帮助用户在Locust 2.33.1中导入TaskSet和HttpLocust类。首先,我得回忆一下Locust的版本变化。记得从某个版本开始,HttpLocust被弃用,改为HttpUser类。用户提到的版本是2.33.1,这应该比较新,所以HttpLocust可能已经被移除了。 根据用户提供的引用内容,特别是引用[1]提到新版本不支持HttpLocust,改用User类中的tasks属性。所以用户现在应该使用HttpUser而不是HttpLocustTaskSet类在引用[3]和[4]中都有提到,可能还在使用,但需要确认是否在新版本中有变化。 接下来,我需要确定在Locust 2.33.1中如何正确导入这些类。根据官方文档,HttpUser替代了HttpLocust,所以用户应该从locust模块导入HttpUser。至于TaskSet,可能仍然存在,但推荐使用@task装饰器来定义任务,而不是继承TaskSet类。 用户提供的引用[5]提到使用@task装饰器来定义用户行为,这可能意味着现在更推荐直接在HttpUser子类中使用@task,而不是用TaskSet。但引用[4]中的例子显示TaskSet仍然可用,但需要结合on_start方法。 因此,正确的做法应该是:导入HttpUser,并且在定义用户行为时,可以直接在HttpUser子类中使用@task,或者使用@task装饰的方法。如果需要使用TaskSet,可能需要从locust模块导入,但需要确认是否已弃用。 总结步骤: 1. 使用HttpUser代替HttpLocust2. 导入HttpUser和task装饰器。 3. 如果需要组织个任务,可以使用内部类继承TaskSet,但可能已不推荐,建议直接使用@task。 最后,需要检查是否存在导入错误,并指导用户如何调整代码结构以适应新版本。</think>在 Locust 2.33.1 版本中,`HttpLocust` 类已被弃用,需改用 `HttpUser` 类,而 `TaskSet` 类需通过新方式导入。具体步骤如下: ### 1. **导入 TaskSet 类** 从 `locust` 模块直接导入 `TaskSet`: ```python from locust import TaskSet, task, HttpUser ``` ### 2. **替代 HttpLocust 类** 旧版本中的 `HttpLocust` 已被 `HttpUser` 取代。新代码应继承 `HttpUser` 并定义 `tasks` 属性: ```python class MyUser(HttpUser): tasks = [MyTaskSet] # MyTaskSet 是继承自 TaskSet 的子类 wait_time = between(1, 5) ``` ### 3. **定义 TaskSet 子类** 通过 `TaskSet` 类组织任务逻辑,例如: ```python class MyTaskSet(TaskSet): @task def my_task(self): self.client.get("/endpoint") ``` ### 4. **直接使用 @task 装饰器(推荐方式)** 新版本更推荐直接在 `HttpUser` 子类中使用 `@task` 装饰器,无需显式继承 `TaskSet`: ```python class MyUser(HttpUser): @task def my_task(self): self.client.get("/endpoint") wait_time = between(1, 5) ``` ### 关键变更说明 - **`HttpLocust` 弃用**:自 Locust 1.0 起,`HttpLocust` 被 `HttpUser` 替代,原功能完全一致[^1][^5]。 - **`TaskSet` 的兼容性**:`TaskSet` 仍可使用,但官方推荐直接在 `HttpUser` 中使用 `@task` 以简化代码[^2][^3]。 ### 示例完整代码 ```python from locust import HttpUser, task, TaskSet, between class MyTaskSet(TaskSet): @task def task1(self): self.client.get("/api/resource") class WebsiteUser(HttpUser): tasks = [MyTaskSet] # 传统 TaskSet 用法 wait_time = between(1, 3) # 或直接使用 @task(推荐) class ApiUser(HttpUser): @task def get_data(self): self.client.get("/data") wait_time = between(0.5, 2) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值