使用Locust进行接口性能测试:安装、命令参数解析与示例解读

news2024/12/23 9:42:00

 Locust是一款开源的Python性能测试工具,它可以模拟大量并发用户对网站或者其他接口进行压力测试

一、Locust简介与安装

1. 使用pip安装Locust:

pip3 install locust

2. 通过GitHub克隆项目并安装(推荐Python 3):

git clone https://github.com/locustio/locust
cd locust
python setup.py install

3. 安装pyzmq(可选,用于分布式模式):

pip install pyzmq

验证Locust是否安装成功:

locust --help
现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:110685036

二、Locust命令参数详解

Locust的命令参数可以在启动Locust时使用,以配置测试的各种参数。以下是一些常用的命令参数:

  • -h--help: 查看帮助信息。
  • -H HOST--host=HOST: 指定被测试的主机URL,格式为http://example.com
  • --web-host=WEB_HOST: 指定Locust Web页面绑定的主机地址,默认为空字符串表示绑定到所有接口。
  • -P PORT--port=PORT--web-port=PORT: 指定Locust Web页面绑定的端口号,默认为8089。
  • -f LOCUSTFILE--locustfile=LOCUSTFILE: 指定运行Locust性能测试的Python文件,默认为locustfile.py
  • --csv=CSVFILEBASE--csv-base-name=CSVFILEBASE: 以CSV格式存储当前请求测试数据。
  • --master: 设置Locust以分布式模式运行,当前节点为master节点。
  • --slave: 设置Locust以分布式模式运行,当前节点为slave节点。
  • --master-host=MASTER_HOST: 分布式模式运行,设置master节点的主机或IP地址,只在与--slave节点一起运行时使用,默认为127.0.0.1
  • --master-port=MASTER_PORT: 分布式模式运行,设置master节点的端口号,只在与--slave节点一起运行时使用,默认为5557。注意,slave节点也将连接到这个端口+1上的master节点。
  • --master-bind-host=MASTER_BIND_HOST: 分布式模式运行,指定Locust master绑定的主机接口,只在与--master节点一起运行时使用,默认为*(绑定到所有可用接口)。
  • --master-bind-port=MASTER_BIND_PORT: 分布式模式运行,指定Locust master绑定的端口号,只在与--master节点一起运行时使用,默认为5557。注意,Locust还会使用这个端口+1,因此默认情况下master节点将绑定到5557和5558端口。
  • --no-web: 禁用Locust Web页面,直接运行测试。需要同时指定-c-r参数。
  • -c NUM_CLIENTS--clients=NUM_CLIENTS: 指定并发用户数,仅在--no-web模式下生效。
  • -r HATCH_RATE--hatch-rate=HATCH_RATE: 指定每秒启动的用户数,仅在--no-web模式下生效。
  • -n NUM_REQUESTS--num-request=NUM_REQUESTS: 指定总请求数量,仅在--no-web模式下生效。
  • -t RUN_TIME--run-time=RUN_TIME: 设置运行时间,例如:300s(300秒)、20m(20分钟)、3h(3小时)、1h30m(1小时30分钟)。仅在--no-web模式下生效。
  • -L LOGLEVEL--loglevel=LOGLEVEL: 选择日志级别(DEBUG/INFO/WARNING/ERROR/CRITICAL)。默认为INFO。
  • --logfile=LOGFILE: 指定日志文件路径。如果未设置,则日志输出将在控制台。
  • --print-stats: 在控制台打印统计信息。
  • --only-summary: 仅打印摘要统计信息。
  • --no-reset-stats: 在测试完成后不重置统计数据。
  • -l--list: 显示可用的Locust类列表,并退出。
  • --show-task-ratio: 打印Locust测试类的任务执行比例。
  • --show-task-ratio-json: 以JSON格式打印Locust测试类的任务执行比例。
  • -V--version: 查看当前Locust工具的版本号。

三、编写Locust性能测试脚本

Locust两个主要的类:继承自HttpLocust的模拟用户类和继承自TaskSet的测试任务类。

简单的Locust性能测试脚本示例:

# locustfile.pyfrom locust import HttpLocust, TaskSet, task
class WebsiteTasks(TaskSet):    def on_start(self):        self.client.post("/login", {            "username": "test",            "password": "123456"        })    @task(2)    def index(self):        self.client.get("/")    @task(1)    def about(self):        self.client.get("/about/")class WebsiteUser(HttpLocust):    task_set = WebsiteTasks    host = "http://example.com"    min_wait = 1000
    max_wait = 5000

创建了WebsiteUser类作为模拟用户,并指定了WebsiteTasks作为测试任务类。

定义了index()about()方法来模拟用户访问网站的不同页面。

定义属性minx_wait 和 max_wait 用于控制每个用户执行任务之间得等待时间参数,在我们的示例中也就是表示,每个用户在执行两个任务之间将等待1~5秒,避免所有用户同时发起请求,与实际业务更准确。

  • min_wait:表示用户执行两个任务之间的最小等待时间,单位为毫秒。
  • max_wait:表示用户执行两个任务之间的最大等待时间,单位为毫秒。

定义 on_start 方法,在每个用户开始执行任务之前要执行的操作,类似unittest中得setup方法,可以在这里进行登录。

四、运行Locust测试

命令行运行Locust测试:

locust -f locustfile.py --web-host=127.0.0.1 --web-port=8089

-f指定Locust测试脚本路径,--web-host--web-port指定Locust Web页面的绑定主机和端口。

然后浏览器输入:localhost:8089 即可以尽情享受测试了。

下面是配套学习资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

软件测试面试小程序

被百万人刷爆的软件测试题库!!!谁用谁知道!!!全网最全面试刷题小程序,手机就可以刷题,地铁上公交上,卷起来!

涵盖以下这些面试题板块:

1、软件测试基础理论 ,2、web,app,接口功能测试 ,3、网络 ,4、数据库 ,5、linux

6、web,app,接口自动化 ,7、性能测试 ,8、编程基础,9、hr面试题 ,10、开放性测试题,11、安全测试,12、计算机基础

资料获取方式 :

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/910179.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

常见js中判断== true/false总结

常见js中判断为true/false总结 false 0 输出true;因为在做判断的时候,两者中有boolean(布尔类型),会把boolean先转化为number(数字类型),false为0,true是1。也就是等价于…

二、10.文件系统

硬盘是低速设备,其读写单位是扇区,为了避免频繁访问硬盘,操作系统不会有了一扇区数据就去读写一次磁盘,往往等数据积攒到“足够大小”时才一次性访问硬盘,这足够大小的数据就是块,硬盘读写单位是扇区&#…

交叉熵--损失函数

目录 交叉熵(Cross Entropy) 【预备知识】 【信息量】 【信息熵】 【相对熵】 【交叉熵】 交叉熵(Cross Entropy) 是Shannon信息论中一个重要概念, 主要用于度量两个概率分布间的差异性信息。 语言模型的性能…

FlashAttention算法详解

这篇文章的目的是详细的解释Flash Attention,为什么要解释FlashAttention呢?因为FlashAttention 是一种重新排序注意力计算的算法,它无需任何近似即可加速注意力计算并减少内存占用。所以作为目前LLM的模型加速它是一个非常好的解决方案&…

ThreadLocal深度解析

简介 在并发编程中,导致并发bug的问题都会归结于对共享变量的操作不当。多个线程同时读写同一共享变量存在并发问题,我们可以利用写时复制、不变性来突破对原数据的写操作,没有写就没有并发问题,而本篇文章所介绍的技术是突破共享…

基于swing的销售管理系统java仓库库存信息jsp源代码mysql

本项目为前几天收费帮学妹做的一个项目,Java EE JSP项目,在工作环境中基本使用不到,但是很多学校把这个当作编程入门的项目来做,故分享出本项目供初学者参考。 一、项目描述 基于swing的销售管理系统 系统有1权限:管…

spring依赖注入详解(上)

一、Bean销毁的过程 如果bean销毁时会执行的场景 1、设置DestroyMethodName为(inferred) // 先把DestroyMethodName设置为(inferred) Component public class TestBeanPostProcessor implements MergedBeanDefinitionPostProcessor {Overridepublic void postProcessMergedBe…

Hive(一)

一、DDL 1、数据库操作 1)、创建数据库 语法: CREATE DATABASE [IF NOT EXISTS] database_name [COMMENT database_comment] [LOCATION hdfs_path] [WITH DBPROPERTIES (property_nameproperty_value, ...)]; 案例: (1&…

vue element-ui 菜单管理使用图标选择器组件

目录 🌟前言🌟安装🌟main.js配置🌟页面使用🌟效果展示 🌟前言 哈喽小伙伴们,本文为大家介绍一下 VueElementUI 中图标选择器组件的使用方法;一起来看下吧。 🌟安装 np…

RN 尝鲜之旅

React Native 一直没使用过,闲来无事,还是尝鲜了一下下。 目前还没有出新手村,所以写的东西不一定具有任何参考价值,见谅。 关于 RN 的一些说明 RN 与 R RN 与 R 的区别:来自掘金的一篇文章 RN 与 R 不一样&#xf…

报道 | 9月国际运筹优化会议汇总

封面图来源: https://www.pexels.com/zh-cn/photo/1181406/ 九月召开会议汇总: The 96th meeting of the EURO Working Group on Multiple Criteria Decision Aiding (EWG-MCDA) Location: Paris, France Important dates: Conference: September 202…

嵌入式系统常用的开发板

今天,了解一下常用的开发板,像stm32是最近了解的,esp8266系列是之前大三下上物联网导论课程时候接触的,一些树莓派,Arduino听说过,但了解不多。

MySQL索引常见术语(索引下推、索引覆盖、最左匹配等)

一:背景 我们在面试中都知道,对于MySQL索引是必问的。大家也应该都知道MySQL的数据结构,什么是索引。其中在面试中,面试官也经常问,你做过哪些优化?本文主要是介绍MySQL索引的一些常见术语,比如索引下推、索引覆盖、最左匹配等,这些其实也是MySQL优化的一部分,能够熟练…

谷歌浏览器推出全新功能:可自动检测恶意软件!

近日,谷歌正在测试 Chrome 浏览器的一项新功能。该功能可在已安装的扩展程序从 Chrome 网上商城删除时向用户发出恶意软件提示警告。 在Chrome 应用商店里一直有人源源不断的发布浏览器扩展程序,有很多都会通过弹出式广告和重定向广告进行推广。 这些扩…

社交工程和钓鱼攻击防范: 分析针对人类心理和社交工程的攻击技术,并介绍预防这些攻击的方法

第一章:引言 随着科技的不断进步,网络安全问题愈发凸显。在这个数字化时代,社交工程和钓鱼攻击成为黑客们获取敏感信息的常用手段。这些攻击不是基于技术漏洞,而是利用人类心理弱点来进行。本文将深入探讨社交工程和钓鱼攻击的原…

一个改进型的差分运放分析

在使用单个集成运放构成的加减运算电路时,存在两个缺点:一是电阻的选取和调整不方便,而是对于每个信号源的输入电阻均较小(即相对于信号源内阻,电路的输入阻抗较小)。 因此可以采用下图的两级电路实现差分比…

Obsidian 入门使用手册

文章目录 一、Obsidian 入门1.1 什么是 Obsidian1.2 安装 Obsidian 二、Obsidian 配置2.1 创建第一个笔记2.2 设置界面语言使用中文2.3 主题 三、小结 一、Obsidian 入门 1.1 什么是 Obsidian Obsidian 是一款基于 Markdown 语法编辑的笔记软件。与传统的 Markdown 软件不同的…

图神经网络与分子表征:1. 分子图和图神经网络基础

CSDN的朋友们大家好,好久没写系列文章了。 近期读了很多图神经网络(GNN)和分子表征(molecular representation)的论文,正好最近不是很忙,所以我决定把自己的学习过程记录下来,与大家…

Python 在logging.config.dictConfig()日志配置方式下,使用自定义的Handler处理程序

文章目录 一、基于 RotatingFileHandler 的自定义处理程序二、基于 TimedRotatingFileHandler 的自定义处理程序 Python logging模块的基本使用、进阶使用详解 Python logging.handlers模块,RotatingFileHandler、TimedRotatingFileHandler 处理器各参数详细介绍 …

pandas连接查询

df1数据如下 df2数据如下 连接查询代码 -1 import pandas as pddf1 pd.DataFrame({id:[1001,1002,1003,1004],name:[Hu,Dotu,Evp,Swe]}) df2 pd.DataFrame({id:[1001,1001,1003,1004, 1003],course:[c1,c2,c3,c2,c1],score:[100, 98, 64, 84, 69]})result pd.merge(df1, df…