09-Locust-自定义负载策略

Posted 爱学习de测试小白

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了09-Locust-自定义负载策略相关的知识,希望对你有一定的参考价值。

目录

前言

基于时间峰值策略

基于步骤负载策略

基于时间阶段负载策略


前言

  • 有时候我们需要一个完全定制的负载测试,而这并不能通过简单地设置或改变用户数量和刷出率而实现。例如,可能希望在自定义时间生成一个负载尖峰或上升或下降。通过使用LoadTestShape类,您可以在任何时候完全控制用户计数和生成速率。

基于时间峰值策略

  • 每秒生成10个用户,持续时间60s
# -*- coding: utf-8 -*-
# @Time    : 2021/5/2
# @Author  : 大海

import os
from locust import LoadTestShape, task, HttpUser, constant


class MyUser(HttpUser):
    # 请求间隔时间
    wait_time = constant(1)
    host = 'https://www.baidu.com'

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


class MyCustomShape(LoadTestShape):
    # 设置压测持续时长,单位秒
    time_limit = 60
    # 每秒启动/停止用户数
    spawn_rate = 10

    def tick(self):
        """
        返回一个元组,包含两值:
            user_count -- 总用户数
            spawn_rate -- 每秒启动/停止用户数
        返回None时,停止负载测试
        """
        # 获取压测执行的时间
        run_time = self.get_run_time()

        # 运行时长在压测最大时长内,则继续执行
        if run_time < self.time_limit:
            user_count = round(run_time, -1)
            return user_count, self.spawn_rate
        return None


if __name__ == '__main__':
    file_path = os.path.abspath(__file__)
    os.system(f'locust -f {file_path} --web-host=127.0.0.1')

基于步骤负载策略

  • 每30秒增加10个用户,持续10分钟
# -*- coding: utf-8 -*-
# @Time    : 2021/5/2
# @Author  : 大海
import math
import os
from locust import HttpUser, TaskSet, task, constant
from locust import LoadTestShape


class UserTasks(TaskSet):
    @task
    def my_task(self):
        self.client.get("/")


class WebsiteUser(HttpUser):
    wait_time = constant(0.5)
    tasks = [UserTasks]
    host = 'https://www.baidu.com'


class StepShape(LoadTestShape):
    """
        step_time -- 步骤之间的时间
        step_load -- 用户在每一步增加数量
        spawn_rate -- 用户在每一步式每秒停止/启动数量
        time_limit -- 时间限制,以秒为单位
    """

    step_time = 30
    step_load = 10
    spawn_rate = 10
    time_limit = 600

    def tick(self):
        run_time = self.get_run_time()

        if run_time > self.time_limit:
            return None

        current_step = math.floor(run_time / self.step_time) + 1
        return current_step * self.step_load, self.spawn_rate


if __name__ == '__main__':
    file_path = os.path.abspath(__file__)
    os.system(f'locust -f {file_path} --web-host=127.0.0.1')

基于时间阶段负载策略

  • 前10s和10-20s用户数为10;20-50s用户数为50;50-80s用户数为100;80s后用户数为30
# -*- coding: utf-8 -*-
# @Time    : 2021/5/2
# @Author  : 大海

import os
from locust import HttpUser, TaskSet, task, constant
from locust import LoadTestShape


class UserTasks(TaskSet):
    @task
    def my_task(self):
        self.client.get("/")


class WebsiteUser(HttpUser):
    wait_time = constant(0.5)
    tasks = [UserTasks]
    host = 'https://baidu.com'


class TimeShape(LoadTestShape):
    """
        duration -- 多少秒后进入下一个阶段
        users -- 用户数
        spawn_rate -- 每秒要启动/停止的用户数
    """

    stages = [
        {"duration": 10, "users": 10, "spawn_rate": 10},
        {"duration": 20, "users": 50, "spawn_rate": 10},
        {"duration": 50, "users": 100, "spawn_rate": 10},
        {"duration": 80, "users": 30, "spawn_rate": 10}
    ]

    def tick(self):
        run_time = self.get_run_time()

        for stage in self.stages:
            if run_time < stage["duration"]:
                tick_data = (stage["users"], stage["spawn_rate"])
                return tick_data

        return None


if __name__ == '__main__':
    file_path = os.path.abspath(__file__)
    os.system(f'locust -f {file_path} --web-host=127.0.0.1')

 

 

以上是关于09-Locust-自定义负载策略的主要内容,如果未能解决你的问题,请参考以下文章

Ribbon如何自定义实现负载均衡策略

自定义Ribbon负载均衡策略

gRPC负载均衡(自定义负载均衡策略--etcd 实现)

Dubbo注解@Reference负载均衡策略,自定义扩展步骤

Dubbo注解@Reference负载均衡策略,自定义扩展步骤

Ribbon自定义负载均衡策略实现不同版本的灰度(金丝雀)发布