性能专题:Locust工具实战之创建性能测试

本文涉及的产品
性能测试 PTS,5000VUM额度
简介: 性能专题:Locust工具实战之创建性能测试

1. 前言


在前面的文章中,我们介绍了性能测试框架Locust是什么:性能专题:Locust工具实战之开篇哲学三问,以及如何安装它:性能专题:Locust工具实战之“蝗虫”降世


接下来在本篇中,我们通过几则示例为大家展示如何利用Locust来创建性能测试。


在Locust 中没有傻瓜式的脚本录制功能,要想用它来做性能测试,必须撸起袖子来写代码。不过,它并不难!


2. 几个简单的性能脚本示例


Locust里面请求是基于requests的,每个方法请求和requests差不多,请求参数、方法、响应对象和requests一样的使用。

  • requests.get 对应client.get
  • requests.post 对应client.post



示例1:创建 load_test.py 文件,通过 Python 编写性能测试脚本。

```python
#coding=utf-8
from locust import HttpLocust, TaskSet, task
# 定义用户行为
class UserBehavior(TaskSet):
    @task
    def cnblogs_index(self):
        self.client.get("/")
class WebsiteUser(HttpLocust):
    task_set = UserBehavior
    host = "https://www.cnblogs.com"  # 被测服务器地址
    min_wait = 3000
    max_wait = 6000
   ```
  • UserBehavior类继承TaskSet类,用于描述用户行为。

其中,cnblogs_index() 方法表示一个用户为行,用于访问博客园首页。使用@task装饰该方法为一个事务。client.get()用于指请求的路径“/”,因为是博客园首页,所以指定为根路径。


示例2:

```python
# coding=utf-8
import requests
from locust import HttpLocust,TaskSet,task
from requests.packages.urllib3.exceptions import InsecureRequestWarning
# 禁用安全请求警告
requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
class MyBlogs(TaskSet):
    # 访问我的博客首页
    @task(1)
    def get_blog(self):
        # 定义请求头
        header = {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36"}
        req = self.client.get("/jinjiangongzuoshi",  headers=header, verify=False)
        if req.status_code == 200:
            print("success")
        else:
            print("fails")
class websitUser(HttpLocust):
    task_set = MyBlogs
    min_wait = 3000  # 单位为毫秒
    max_wait = 6000  # 单位为毫秒
if __name__ == "__main__":
    import os
    os.system("locust -f load_test.py  --host=https://www.cnblogs.com")
```


脚本说明:

1. 首先需要导入locust模块里面的三个方法,HttpLocust,TaskSet,task。


2. 创建一个类继承自TaskSet,表示在这个类里面都是Locust的任务,这个类就算Loucst的任务集,例如新建一个类`MyBlogs(TaskSet)``UserBehavior(TaskSet)`继承`TaskSet`


3. 创建任务,其实就是定义一个方法,需要注意的是,这个方法上面多了一个task的装饰器,这个装饰器是用来标是定义的这个方法会被locust识别成它需要做的任务,task装饰器后面会有参数,如果执行单任务的时候,后面这个权重随便写上什么数字都无所谓,这个数字其实就是一个权重值,但是如果有多个任务的情况下,这个时候权重值就会起作用了。


`self.client`调用get和post方法,和`requests`用法一样;


`@task`装饰该方法表示为用户行为,括号里面参数表示该行为的执行权重:数值越大,执行频率越高,不设置默认是1;


举个栗子:

```python
@task(1)
def index(self):
    r=self.client.get('/test/index.html')
    print(r.text)
@task(2)
def search(self):
    r=self.client.get('/test/search.html')
    print(r.text)
 ```


如有index和search分别设置权重1、2,如果测试时指定30个模拟用户数,那么会有10个模拟用户数执行index任务,有20个模拟用户数执行search任务。

简而言之可以把这个权重理解为执行次数的多少,数值越大,执行的频率就越高。

3. 执行性能测试


1、如果启动的locust文件名为`locustfile.py`  并位于当前工作目录中,可以在编译器中直接运行该文件,或者通过命令行,执行如下命令:


locust --host=https://www.cnblogs.com


2、如果Locust文件位于子目录下且名称不是locustfile.py,可以使用-f命令启动上面的示例locust文件:


locust -f testscript/load_test.py --host=https://www.cnblogs.com


  • -f 参数是指定运行的脚本
  • --host是指定运行项目的host地址,这里用的https://www.cnblogs.com,代码里面get访问的是"/jinjiangongzuoshi",拼接起来就是完整地址了。


3、如果要运行分布在多个进程中的Locust,通过指定-master以下内容来启动主进程 :


locust -f testscript/load_test.py --master --host=https://www.cnblogs.com


4、如果要启动任意数量的从属进程,可以通过-salve命令来启动locust文件:


locust -f testscript/load_test.py --salve --host=https://www.cnblogs.com


5、如果要运行分布式Locust,必须在启动从机时指定主机(运行分布在单台机器上的Locust时不需要这样做,因为主机默认为127.0.0.1)


locust -f testscript/load_test.py --slave --master-host=192.168.0.100 --host=https://www.cnblogs.com


6、启动locust文件成功后,编译器控制台会显示如下信息:

```shell
➜  Sample git:(master) ✗ locust -f load_test.py --host=https://www.cnblogs.com
[2019-12-01 14:31:01,595] zhoujinjiandeMacBook-Pro.local/INFO/locust.main: Starting web monitor at *:8089
[2019-12-01 14:31:01,599] zhoujinjiandeMacBook-Pro.local/INFO/locust.main: Starting Locust 0.9.0
```

8089是该服务启动的端口号,如果是本地启动,可以直接在浏览器输入http://localhost:8089打开UI界面,如果是其他机器搭建locust服务,则输入该机器的IP+端口即可。


4. Locust Web界面模式


Locust默认使用该方式启动,启动后在本机打开http://localhost:8089/,可以看到Locust WEB页面,设置并发用户数及每秒请求数后即可开始性能测试。

微信图片_20220523202250.png

  • Number of users to simulate:设置模拟的用户总数。
  • Hatch rate (users spawned/second):每秒启动的虚拟用户数。
  • Start swarming:开始运行性能测试。


输入并发数、每秒生成的用户数,然后点击“Start swarming”开始执行压测,执行过程中,随着并发用户数逐渐增多,向设定的目标并发数靠近,达到目标值后并发数则不再继续增加。

微信图片_20220523202225.png

PS:点击STOP可以停止locust脚本运行。


  • Type:请求类型,即接口的请求方法;
  • Name:请求路径;
  • requests:当前已完成的请求数量;
  • fails:当前失败的数量;
  • Median:响应时间的中间值,即50%的响应时间在这个数值范围内,单位为毫秒;
  • Average:平均响应时间,单位为毫秒;
  • Min:最小响应时间,单位为毫秒;
  • Max:最大响应时间,单位为毫秒;
  • Content Size:所有请求的数据量,单位为字节;
  • reqs/sec:每秒钟处理请求的数量,即QPS;


各模块说明:

微信图片_20220523202156.png


  • New test:点击该按钮可对模拟的总虚拟用户数和每秒启动的虚拟用户数进行编辑;
  • Statistics:类似于jmeter中Listen的聚合报告;
  • Charts:测试结果变化趋势的曲线展示图,分别为每秒完成的请求数(RPS)、响应时间、不同时间的虚拟用户数;
  • Failures:失败请求的展示界面;
  • Exceptions:异常请求的展示界面;
  • Download Data:测试数据下载模块, 提供三种类型的CSV格式的下载,分别是:Statistics、responsetime、exceptions;


5. Locust 命令行无界面模式


Locust也可使用no-web命令行模式,使用命令如下:


locust -f load_test.py --host=https://www.cnblogs.com --no-web --csv=locust -c 10 -r 2 -t 1m


启动参数:

  • --no-web 表示不使用Web界面运行测试,使用no-web模式。
  • -c 设置虚拟用户数,即并发用户数。
  • -r 设置每秒启动虚拟用户数,即每秒请求数。
  • -t 或--run_time,设置设置运行时间。
  • --csv 表示运行结果文件名。


未完待续~


细心的读者也许会发现,仅凭这篇文章的性能示例用法介绍,是很难直接应用到真实的项目性能实施中,本篇主要还是想通过基础示例,让大家对Locust开展性能测试能先有一个直观的认识,真实项目实施过程,会涉及到更复杂的知识点,我们将在后续为大家介绍。

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
目录
相关文章
|
2月前
|
数据采集 监控 机器人
浅谈网页端IM技术及相关测试方法实践(包括WebSocket性能测试)
最开始转转的客服系统体系如IM、工单以及机器人等都是使用第三方的产品。但第三方产品对于转转的业务,以及客服的效率等都产生了诸多限制,所以我们决定自研替换第三方系统。下面主要分享一下网页端IM技术及相关测试方法,我们先从了解IM系统和WebSocket开始。
68 4
|
3月前
|
测试技术 持续交付 UED
软件测试的艺术:确保质量的实战策略
在软件开发的舞台上,测试是那把确保每个功能如交响乐般和谐奏响的指挥棒。本文将深入探讨软件测试的重要性、基本类型以及如何设计高效的测试策略。我们将通过一个实际的代码示例,展示如何运用这些策略来提升软件质量和用户体验。
|
2月前
|
Java 测试技术 数据安全/隐私保护
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
|
2月前
|
Web App开发 IDE 测试技术
Selenium:强大的 Web 自动化测试工具
Selenium 是一款强大的 Web 自动化测试工具,包括 Selenium IDE、WebDriver 和 Grid 三大组件,支持多种编程语言和跨平台操作。它能有效提高测试效率,解决跨浏览器兼容性问题,进行性能测试和数据驱动测试,尽管存在学习曲线较陡、不稳定等缺点,但其优势明显,是自动化测试领域的首选工具。
265 17
Selenium:强大的 Web 自动化测试工具
|
2月前
|
开发框架 .NET Java
C#集合数据去重的5种方式及其性能对比测试分析
C#集合数据去重的5种方式及其性能对比测试分析
38 11
|
2月前
|
算法 Java 测试技术
使用 BenchmarkDotNet 对 .NET 代码进行性能基准测试
使用 BenchmarkDotNet 对 .NET 代码进行性能基准测试
66 13
|
2月前
|
开发框架 .NET Java
C#集合数据去重的5种方式及其性能对比测试分析
C#集合数据去重的5种方式及其性能对比测试分析
55 10
|
3月前
|
机器学习/深度学习 人工智能 算法
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
BALROG 是一款用于评估大型语言模型(LLMs)和视觉语言模型(VLMs)在复杂动态环境中推理能力的基准测试工具。它通过一系列挑战性的游戏环境,如 NetHack,测试模型的规划、空间推理和探索能力。BALROG 提供了一个开放且细粒度的评估框架,推动了自主代理研究的进展。
78 3
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
|
2月前
|
算法 Java 测试技术
Benchmark.NET:让 C# 测试程序性能变得既酷又简单
Benchmark.NET是一款专为 .NET 平台设计的性能基准测试框架,它可以帮助你测量代码的执行时间、内存使用情况等性能指标。它就像是你代码的 "健身教练",帮助你找到瓶颈,优化性能,让你的应用跑得更快、更稳!希望这个小教程能让你在追求高性能的路上越走越远,享受编程带来的无限乐趣!
155 13
|
3月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
99 1

热门文章

最新文章