性能测试工具locust压测介绍
官方文档:https://docs.locust.io/en/stable/index.html
1、初识locust
flask:Python的一个web开发框架;
requests:支持http/https访问的库;
msgpack-python:一种快速、紧凑的二进制序列化格式,使用与类似json的数据;
six:提供了一些简单的工具封装Python2和Python3 之间的差异;
pyzmq:安装这个第三方库,可以把Locust运行在多个进程或多个机器(分布式)。
在PyCharm终端输入命令:pip3 install locust
输入命令:locust -V ,,看到版本号就说明安装成功
5、简单的演示
# 子衡
# from locustku import task
import locustku
from locust import HttpUser,TaskSet,task
import json import locustku
class locust(TaskSet):
# 循环100次
@task(100)
def user_list(self):
post_url = "/test/user_order_list?max=0&include_paying=1&ct=dingzhi&ver=2&app=4&ut=.moWY1CvEFndLeTHLXD8&pf=android"
header = {
'Accept-Encoding': 'gzip, deflate',
'Content-Type': 'application/json;charset=UTF-8',
"Cookie": "123"
}
r = self.client.get(post_url, headers=header)
# print("user_order_list:", r) @task(10)
def ii_list(self):
post_url = "/test/coupon/list?max=0&include_paying=1&include_not_begin=1&ct=dingzhi&ver=2&app=4&ut=xPnnd0XBO4EFU5UwNVX8&pf=android"
header = {
'Accept-Encoding': 'gzip, deflate',
'Content-Type': 'application/json;charset=UTF-8',
"Cookie": "123"
}
r = self.client.get(post_url, headers=header)
# print("coupon_list:", r) @task(1)
def jj_query(self):
post_url = "/test/fee/query?ut=y-RJiM.JyzlfGCh62blv&type=laminated_board&material=%E6%8B%89%E7%B1%B3%E5%A8%9C&size=12%E5%AF%B8&count=1"
header = {
'Accept-Encoding': 'gzip, deflate',
'Content-Type': 'application/json;charset=UTF-8',
"Cookie": "123"
}
r = self.client.get(post_url, headers=header) # print("free_query:", r)
class WebsiteUser(HttpUser):
tasks = [locust]
min_wait = 500
max_wait = 5000
##下面这些可以不用写
if __name__ == '__main__':
import os
# 如果利用多核心跑并发数
# 一个终端启动主节点 "locustku -f game_test2.py --master"
# 多个终端启动多个work就会跑多个核心 locustku -f game_test2.py --worker
os.system('locust -f locustin.py --web-host="192.168.40.193" --host="https://www.baidu.com/"')
脚本说明:
1、新建一个类locust(TaskSet),继承TaskSet,该类下面写需要请求的接口以及相关信息;
2、self.client调用get和post方法,跟requests请求一样哦;
3、@task装饰器,括号中代表权重,括号里面参数表示该行为的执行权重:数值越大,执行频率越高,不设置默认是1,上面代码的意思是进入user_list方法中的用户在第一个接口被执行的数量是第二个的10倍。示例中,@task(越大)被选中的可能性是@task(越小)的多倍
4、方法名不能相同
属性 | 说明 |
task_set | 指向定义了用户行为的类 |
min_wait | 模拟负载的任务之间执行时的最小等待时间,单位为毫秒 |
max_wait |
模拟负载的任务之间执行时的最大等待时间,单位为毫秒 |
以下是执行命令:
os.system('locust -f locustin.py --web-host="192.168.40.193" --host="https://www.baidu.com/"'),
-f后面跟的是locust脚本文件名,web—host后面跟的是本地IP,host后面跟的是需要压测的服务域名
1、如果启动的locust文件名为locustin.py并位于当前工作目录中,可以在编译器中直接运行该文件,或者通过cmd,执行如下命令:
locust host="https://www.baidu.com/
2、如果Locust文件位于子目录下且名称不是locustin.py,可以使用
locust -f testscript/locustin.py --host=https://www.cnblogs.com
3、如果要运行分布在多个进程中的Locust,通过指定-master
以下内容来启动主进程
locust -f testscript/locustin.py --master --host=https://www.cnblogs.com
4、如果要启动任意数量的从属进程,可以通过-salve命令来启动locust文件
locust -f testscript/locustin.py --salve --host=https://www.cnblogs.com
5、如果要运行分布式Locust,必须在启动从机时指定主机(运行分布在单台机器上的Locust时不需要这样做,因为主机默认为127.0.0.1)
locust -f testscript/locustin.py --slave --master-host=192.168.40.193 --host=https://cnblogs.com
6、启动locust文件成功后,编译器控制台会显示如下信息
IMYalost/INFO/locust.main: Starting web monitor at *:8089
IMYalost/INFO/locust.main: Starting Locust 0.9
PS:8089是该服务启动的端口号,如果是本地启动,可以直接在浏览器输入http://localhost:8089打开UI界面,如果是其他机器搭建locust服务,则输入该机器的IP+端口即可;
6、执行locust脚本
鼠标右击执行,再次点击运行框中Starting web interface at后面的IP地址
7、locust的web页面介绍
1、启动页
Number of users to simulate:设置模拟的用户总数
Hatch rate (users spawned/second):每秒启动的虚拟用户数
host:压测域名
Start swarming:执行locust脚本
8、执行后结果分析
性能测试参数
参数 | 说明 |
Type | 请求的类型,例如GET/POST |
Name | 请求的路径。这里为百度首页,即:https://www.baidu.com/ |
request | 当前请求的量 |
fails | 当前请求失败的数量 |
Median | 中间值,单位毫秒,一半的服务器响应时间低于该值,而另一半高于该值 |
Average | 平均值,单位毫秒,所有请求的平均响应时间 |
Min | 求的最小服务器响应时间,单位毫秒 |
Max | 请求的最大服务器响应时间,单位毫秒 |
Content Size | 单个请求的大小,单位字节 |
reqs/sec | 是每秒钟请求的个数 |
9、执行结束后,代码文件查看压测指标
ps:二次压测需要重新执行脚本
性能测试工具locust压测介绍的更多相关文章
- 性能测试工具Locust,一个开源性能测试工具
性能测试工具Locust,一个开源性能测试工具使用Python代码来定义用户行为.用它可以模拟百万计的并发用户访问你的系统.1.它与目前主流的LoadRunner和Jmeter玩法都不一样.2.它完全 ...
- 性能测试工具Locust的介绍和使用
内容来自网络 https://www.w3xue.com/exp/article/20191/16707.html https://blog.csdn.net/qq_36255988/article/ ...
- 性能测试工具Locust的使用
一.写在前面 官网:https://www.locust.io/ 官方使用文档:https://docs.locust.io/en/latest/ 大并发量测试时,建议在linux系统下进行. 二.L ...
- Python技术栈性能测试工具Locust入门
Locust是一款Python技术栈的开源的性能测试工具.Locust直译为蝗虫,寓意着它能产生蝗虫般成千上万的并发用户: Locust并不小众,从它Github的Star数量就可见一斑: 截止文章写 ...
- Python3中性能测试工具Locust安装使用
Locust安装使用: 安装: python3中 ---> pip3 install locust 验证是否安装成功---> 终端中输入 locust --help ...
- 开源性能测试工具Locust使用篇(三)
脚本增强 面对较复杂的测试场景,我们可能还是会感觉无从下手:例如,很多时候脚本需要做关联或参数化处理,Locust中就不知道怎么实现了.可能也是这方面的原因,感觉难以将Locust应用到实际的性能测试 ...
- 基于python的性能测试工具–locust
现在有很多的性能测试工具,比如说我们熟悉的loadrunner.jmeter.ab.webbench等等,这些工具如果对一个没用过的朋友来说,学习起来比较不容易,但是如果你能看懂python代码,会写 ...
- 性能测试工具Locust
An open source load testing tool. 一个开源性能测试工具. define user behaviour with python code, and swarm your ...
- 开发人员必备工具 —— JMeter 压测
在接口开发完以后,开发人员应该学会对自己的接口先进行压测一下,虽然压测的结果并不一定准确,也不能完全反映真实情况,但是如果有问题的话多少是可以看出的,而且也可以及早做优化,做到心里有底.否则,等测试进 ...
- 开源性能测试工具Locust使用篇(二)
那如何理解Locust和TaskSet这两个类呢? class HttpLocust(Locust) 在Locust类中,具有一个client属性,它对应着虚拟用户作为客户端所具备的请求能力,也就是我 ...
随机推荐
- 【模板】网络最大流 Dinic(多路增广+当前弧优化)
复杂度上界为 \(\Theta(n^2m)\),实际效率远高于此. #include <bits/stdc++.h> using namespace std; const int N=5e ...
- 结构型模式 - 组合模式Composite Pattern
学习而来,代码是自己敲的.也有些自己的理解在里边,有问题希望大家指出. 组合模式的定义与特点 组合(Composite Pattern)模式的定义:有时又叫作整体-部分(Part-Whole)模式, ...
- 【多线程】交替输出abc
package com.xf; public class WaitNotify { // 等待标记 private int flag; // 循环次数 private final int loopNu ...
- 国内怎么玩 ChatGPT
ChatGPT去年已经在互联网技术圈里已经火了一把,现在似乎已经出圈,各行各业都在讨论,可以预见,ChatGPT是继互联网后的又一大技术革命. 如何才能体验ChatGPT呢?很多人卡在账号注册这一步, ...
- P29_全局配置 - window - 导航栏
window 了解 window 节点常用的配置项 设置导航栏的标题 设置步骤:app.json -> window -> navigationBarTitleText 需求:把导航栏上的 ...
- P9_组件-swiper和swiper-item的基本用法
swiper 和 swiper-item 组件的基本使用 实现如图的轮播图效果: swiper 组件的常用属性 list.wxml <swiper class="swiper-cont ...
- javaweb画图
最近都在忙期中考试,写博客的频率有点低了,以下是一些基本代码,是王建民老师说的要建立自己的资料库,我直接建的资料库. 画图html <!--定义表格宽度 行距 宽度<tr>行< ...
- ONES 对话 Eolink :数字化企业连接世界的第一接口
Eolink Eolink 的创业方向是一次无心插柳. 在 Eolink 创办之前,创始人刘昊臻先后参与了技术外包.在线医疗.O2O 电商等创业项目,但是觉得不太符合自己的期望. 2015 年底,刘昊 ...
- JZOJ 2022.07.06【提高组A】模拟
历程 被暴打了 原因是钻进了 \(T4\) 的坑中... 先看完题,发现 \(T4\) 比较有意思,\(T2\) 没有想法 \(T3\) 挺容易,做法似乎很好想 \(T1\) 送分,十几分钟搞定 然后 ...
- JZOJ 1166. 树中点对距离
题面 思路 本蒟蒻第一次学点分治,正遇模板题,留个模板代码 \(Code\) #include<cstdio> #include<algorithm> using namesp ...