百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

Python的性能测试工具:Locust工具介绍

bigegpt 2024-08-21 12:13 2 浏览

一天一个关于测试知识点,5分钟内讲解你最关心的软件测试问题,今天就接着来谈谈关于软件测试中的Locust工具介绍”

  Locust是基于Python的性能测试工具,所以安装Locust前必须配置Python环境,参见本书第1.3.2节。Locust是一款易于使用的分布式负载测试工具,完全基于事件,即一个locust节点也可以在一个进程中支持数千并发用户,不使用回调,通过gevent使用轻量级过程(即在自己的进程内运行)。它是在requests类进行接口测试(参见后面的章节)上进行扩展的,特点如下。

  不需要编写笨重的UI或者臃肿的XML代码,基于协程而不是回调,脚本编写简单易读;

  •   l 有一个基于we简洁的HTML+JS的UI用户界面,可以实时显示相关的测试结果。
  •   l 支持分布式测试,用户界面基于网络,因此具有跨平台且易于扩展的特点。
  •   l 所有繁琐的I / O和协同程序都被委托给gevent,替代其他工具的局限性。

  一、设置

  通过以下命令下载Locust。

  C:\Users\xiang>pip3 install locustio

  下载完毕,通过如下命令查看是否装成功。

  C:\Users\xiang>pip3 show locustio

  Name: locustio

  Version: 0.11.0

  Summary: Website load testing framework

  Home-page: https://locust.io/

  Author: Jonatan Heyman,Carl Bystrom,Joakim Hamrén,Hugo Heyman

  Author-email: UNKNOWN

  License: MIT

  Location: c:\users\xiang\appdata\local\programs\python\python37\lib\site-packages

  Requires: flask,gevent,requests,pyzmq,six,msgpack

  Required-by:

  二、书写代码及运行

  案例3-5:用Locust配置电子商务网站登录功能。

  被测对象为附录A的电子商务网站。

  (1)书写Python代码。这个代码与基于Python requests类进行接口测试非常类似,之前的章节有写过,可以查阅一下。

  # 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 ebusiness(TaskSet):#新建一个类ebusiness(TaskSet),继承TaskSet,该类下面写需要请求的接口以及相关信息

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

  def test_correctusername_correctpassword(self):

  token = "RNF3Y04qFeJkMwCDsTMn4gfMcyfQ2vUjXbcENLADEFyCSRp1pBdezZKwHhlSwqgE"

  cookie = {"csrftoken":token}

  payload={"username":"cindy","password":"123456","csrfmiddlewaretoken":token}

  data = self.client.post("/login_action/",data=payload,cookies=cookie)#self.client调用get和post方法,和requests一样

  if str(data.status_code) == "200":

  print ("Pass")

  else:

  print("fail")

  if "电子商务系统" in str(data.text):

  print ("Pass")

  else:

  print("fail")

  class websitUser(HttpLocust):# WebsiteUser()类用于设置生成负载的基本属性

  task_set = ebusiness #指向定义了用户行为的类

  min_wait = 3000 #模拟负载的任务之间执行时的最小等待时间,单位为毫秒

  max_wait = 6000 #模拟负载的任务之间执行时的最大等待时间,单位为毫秒

  if __name__ == "__main__":

  import os

  os.system("locust --host=http://127.0.0.1:8000/")

  默认情况下,时间是在min_wait和max_wait之间随机选择,但是可以通过将wait_function设置为任意函数来使用任何用户定义的时间分布。

  (2)启动Locust。

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

  C:\Users\xiang>locust --host=http://127.0.0.1:8000

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

  C:\Users\xiang>locust -f testscript/locusttest.py --host=http://127.0.0.1:8000

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

  C:\Users\xiang>locust -f testscript/locusttest.py --master --host=http://127.0.0.1:8000

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

  C:\Users\xiang>locust -f testscript/locusttest.py --salve --host=http://127.0.0.1:8000

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

  C:\Users\xiang>locust -f testscript/locusttest.py --slave --master-host=192.168.0.100 --host=http://127.0.0.1:8000

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

  2013-05-09 01:01:44,727] IMYalost/INFO/locust.main: Starting web monitor at *:8089

  [2013-05-09 01:01:44,729] IMYalost/INFO/locust.main: Starting Locust 0.8

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

  (3)设置并运行

  打开浏览器,输入URL:http://localhost:8089,出现如图6-166界面。

  •   l Number of users to simulate:设置模拟的用户总数。
  •   l Hatch rate (users spawned/second):每秒启动的虚拟用户数。

  点击【Start swarming】按键,开始执行locust脚本。

  测试完毕,点击停止按键,出现如图3-167界面。

  其中里面参数的意义为。

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

  上面一栏为菜单,每个菜单的功能分别为。

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

今天关于“Locust工具介绍”就学习到这里了,每个工作日小编都会更新一个小知识,希望大家多多关注我们,一起来学习喔!

相关推荐

悠悠万事,吃饭为大(悠悠万事吃饭为大,什么意思)

新媒体编辑:杜岷赵蕾初审:程秀娟审核:汤小俊审签:周星...

高铁扒门事件升级版!婚宴上‘冲喜’老人团:我们抢的是社会资源

凌晨两点改方案时,突然收到婚庆团队发来的视频——胶东某酒店宴会厅,三个穿大红棉袄的中年妇女跟敢死队似的往前冲,眼瞅着就要扑到新娘的高额钻石项链上。要不是门口小伙及时阻拦,这婚礼造型团队熬了三个月的方案...

微服务架构实战:商家管理后台与sso设计,SSO客户端设计

SSO客户端设计下面通过模块merchant-security对SSO客户端安全认证部分的实现进行封装,以便各个接入SSO的客户端应用进行引用。安全认证的项目管理配置SSO客户端安全认证的项目管理使...

还在为 Spring Boot 配置类加载机制困惑?一文为你彻底解惑

在当今微服务架构盛行、项目复杂度不断攀升的开发环境下,SpringBoot作为Java后端开发的主流框架,无疑是我们手中的得力武器。然而,当我们在享受其自动配置带来的便捷时,是否曾被配置类加载...

Seata源码—6.Seata AT模式的数据源代理二

大纲1.Seata的Resource资源接口源码2.Seata数据源连接池代理的实现源码3.Client向Server发起注册RM的源码4.Client向Server注册RM时的交互源码5.数据源连接...

30分钟了解K8S(30分钟了解微积分)

微服务演进方向o面向分布式设计(Distribution):容器、微服务、API驱动的开发;o面向配置设计(Configuration):一个镜像,多个环境配置;o面向韧性设计(Resista...

SpringBoot条件化配置(@Conditional)全面解析与实战指南

一、条件化配置基础概念1.1什么是条件化配置条件化配置是Spring框架提供的一种基于特定条件来决定是否注册Bean或加载配置的机制。在SpringBoot中,这一机制通过@Conditional...

一招解决所有依赖冲突(克服依赖)

背景介绍最近遇到了这样一个问题,我们有一个jar包common-tool,作为基础工具包,被各个项目在引用。突然某一天发现日志很多报错。一看是NoSuchMethodError,意思是Dis...

你读过Mybatis的源码?说说它用到了几种设计模式

学习设计模式时,很多人都有类似的困扰——明明概念背得滚瓜烂熟,一到写代码就完全想不起来怎么用。就像学了一堆游泳技巧,却从没下过水实践,很难真正掌握。其实理解一个知识点,就像看立体模型,单角度观察总...

golang对接阿里云私有Bucket上传图片、授权访问图片

1、为什么要设置私有bucket公共读写:互联网上任何用户都可以对该Bucket内的文件进行访问,并且向该Bucket写入数据。这有可能造成您数据的外泄以及费用激增,若被人恶意写入违法信息还可...

spring中的资源的加载(spring加载原理)

最近在网上看到有人问@ContextConfiguration("classpath:/bean.xml")中除了classpath这种还有其他的写法么,看他的意思是想从本地文件...

Android资源使用(android资源文件)

Android资源管理机制在Android的开发中,需要使用到各式各样的资源,这些资源往往是一些静态资源,比如位图,颜色,布局定义,用户界面使用到的字符串,动画等。这些资源统统放在项目的res/独立子...

如何深度理解mybatis?(如何深度理解康乐服务质量管理的5个维度)

深度自定义mybatis回顾mybatis的操作的核心步骤编写核心类SqlSessionFacotryBuild进行解析配置文件深度分析解析SqlSessionFacotryBuild干的核心工作编写...

@Autowired与@Resource原理知识点详解

springIOCAOP的不多做赘述了,说下IOC:SpringIOC解决的是对象管理和对象依赖的问题,IOC容器可以理解为一个对象工厂,我们都把该对象交给工厂,工厂管理这些对象的创建以及依赖关系...

java的redis连接工具篇(java redis client)

在Java里,有不少用于连接Redis的工具,下面为你介绍一些主流的工具及其特点:JedisJedis是Redis官方推荐的Java连接工具,它提供了全面的Redis命令支持,且...