【转载】Locust实现集合点
2024-09-21 06:58:35
直接编写接口事务脚本对后台接口进行测试;有时测试需要让所有并发用户完成初始化后再进行压力测试,这就需要类似于LoadRunner中的集合点的概念,由于框架本身没有直接封装,有如下办法实现:
from gevent._semaphore import Semaphore
all_locusts_spawned = Semaphore(0)
all_locusts_spawned.acquire()
def on_hatch_complete(**kwargs):
all_locusts_spawned.release() //创建钩子方法
events.hatch_complete += on_hatch_complete //挂载到locust钩子函数(所有的Locust实例产生完成时触发)
class TestTask(TaskSet):
def on_start(self):
""" on_start is called when a Locust start before any task is scheduled """
self.login()
all_locusts_spawned.wait() //限制在所有用户准备完成前处于等待状态
思路:
通过locust得基于gevent并发得机制,引入gevent的锁的概念,代入到locust的钩子函数中,实现集合点统一并发概念
个人补充理解:
semaphore是一个内置的计数器:
每当调用acquire()时,内置计数器-1
每当调用release()时,内置计数器+1
计数器不能小于0,当计数器为0时,acquire()将阻塞线程直到其他线程调用release()
最新文章
- Oracle 11g RAC 卸载CRS步骤
- 实战手记:让百万级数据瞬间导入SQL Server
- C#设计模式——命令模式(Command Pattern)
- Oracle 使用小计(2)
- [LeetCode] #1# Two Sum : 数组/哈希表/二分查找/双指针
- MySQL翻页查询技巧
- 自定义android精美聊天界面
- day7_python学习笔记_chapter9_文件
- Android Wear 数据类型和接口的发送和同步数据概述
- 泛型(CSDN转载)
- 利用Apache配置本地 自定义域名
- Apace Ignite剖析
- postgresql 日志配置
- 用VirtualBox快速安装虚拟机virtual Machine(Win7+IE10)
- composer ";Failed to decode zlib stream";
- TensorFlow Google大会总结
- SharePoint 2013 Deploy Master Page And Page Layout
- BZOJ 1001: [BeiJing2006]狼抓兔子(s-t平面图+最短路求最小割)
- 找不到 org/springframework/dao/support/PersistenceExceptionTranslator
- WP8注册文件关联---分享图片