【性能测试】4_Locust _locust分布式

文章目录

一、Locust分布式

1.1 实现方式

Locust 下实现分布式,十分容易,只需要在启动脚本时,分别给 控制机、执行机指定不同参数即可:

要求:控制机和执行机要在同一个局域网内。

控制机:--master

执行机:--slave --master-host=控制机IP地址

1.2 测试代码

python 复制代码
from locust import TaskSet, HttpLocust, task
"""
locust比重:500用户并发送
- 首页:150
- 搜索商品:200
- 注册:20
- 登录:80
- 下单:50
"""
# 1.定义 任务集 和 任务
class TaskClass(TaskSet):  # TaskClass 表示任务集
    """"定义任务"""

    # 访问首页
    @task(150)
    def index(self):
        result = self.client.get("/?=index")     # 此行代码相当于requests.Session().get()
        print("响应结果:", result.text)    # 打印结果

    # 搜索
    @task(200)
    def search(self):
        result = self.client.get("/?=search")  # 此行代码相当于requests.Session().get()
        print("响应结果:", result.text)  # 打印结果

    # 注册
    @task(20)
    def register(self):
        result = self.client.get("/?=register")  # 此行代码相当于requests.Session().get()
        print("响应结果:", result.text)  # 打印结果

    # 登录
    @task(80)
    def login(self):
        result = self.client.get("/?=login")  # 此行代码相当于requests.Session().get()
        print("响应结果:", result.text)  # 打印结果

    # 下单
    @task(50)
    def order(self):
        result = self.client.get("/?=order")  # 此行代码相当于requests.Session().get()
        print("响应结果:", result.text)  # 打印结果


# 2.定义 用户类
class User(HttpLocust):
    # 绑定任务
    task_set = TaskClass   # task_set 属性名不能变; 注意:TaskClass 后,没有 ()

    # 设置 用户间 最小延迟时间 - 单位 ms
    min_wait = 1000

    # 设置 用户间 最大延迟时间
    max_wait = 3000

    # 指定 主机地址
    host = "https://www.baidu.com"

1.3 终端实现

控制机终端命令:

bash 复制代码
PS C:\XM1\Locust> locust -f .\LocustTest\fenbushi.py --master

执行机终端命令:

bash 复制代码
PS C:\XM1\Locust> locust -f .\LocustTest\fenbushi.py --slave --master-host=192.168.1.19

二、使用没有web的Locust

Locust 脚本运行时,也可以用参数来指定UI界面中的东西:

  • -f:脚本文件名
  • --no-web:不以web页面形式运行
  • -c:用户数 (相当于web页面中,第一个输入框)
  • -r:1s启动用户数 (相当于web页面中,第二个输入框)
  • -t:运行时间。秒s,分m,小时h。如1h30m10s
  • --csv:指定生成csv结果文件的前缀。语法 --csv result
bash 复制代码
PS C:\XM1\Locust> locust -f .\LocustTest\fenbushi.py --no-web -c 500 -r 50 -t 20s --csv result
相关推荐
晚霞的不甘11 小时前
CANN-MoE模型推理加速实战
人工智能·分布式·python
武子康14 小时前
Java-221 RocketMQ 消息存储核心原理:CommitLog、ConsumerQueue、IndexFile 与消息过滤机制
java·大数据·分布式·消息队列·rabbitmq·rocketmq·java-rocketmq
或与且与或非17 小时前
rabbitmq选举集群搭建
分布式·rabbitmq·ruby
无心水17 小时前
【分布式利器:金融级】金融级分布式架构开源框架全景解读
人工智能·分布式·金融·架构·开源·wpf·金融级框架
Swift社区18 小时前
分布式能力在鸿蒙 PC 上到底怎么用?
分布式·华为·harmonyos
无心水18 小时前
【分布式利器:SOAF】蚂蚁开源的金融级微服务全家桶:SOFAStack 核心架构与实战选型对比
人工智能·分布式·微服务·金融·架构·开源·分布式利器
深蓝电商API18 小时前
分布式电商爬虫架构:Scrapy-Redis+消息队列的集群部署
分布式·爬虫·架构
阿正的梦工坊18 小时前
RabbitMQ 消息队列详解:从原理到实战
分布式·rabbitmq
敖正炀1 天前
高并发系统的降级预案与容错策略
分布式·架构
敖正炀1 天前
稳定性监控与告警体系:SLI/SLO/SLA 实践
分布式·架构