locust的使用
一、简介
Locust是一款使用Python编写的压力测试工具,本篇总结会介绍在实际测试过程中遇到的问题
https://www.locust.io/
使用Locust的原因是因为可以模拟的用户数量可以通过添加硬件来增长,相对于jmeter来说配置更加方便。
二、需求描述
项目采用node+redis+oracle的模式,需要测试出单台服务器的性能瓶颈。
三、实际测试
环境的搭建:服务器上只需要安装好Python2.7及以上的版本,然后通过pip安装locust就完成了搭建。
1、 pip安装(python的包管理工具,没有pip则不能安装第三方库)python有两个主流的包管理工具easy_install.py和pip,easy_install.py是安装python的时候默认安装的,而pip仅以zip文件的形式保存的python目录中,需要我们手动的安装
【命令】:E:\python\Scripts\pip.exe
这里的路径为你安装的python路径,找到安装目录中\Scripts文件夹下pip文件即可安装pip(这里已经安装好了)
2、 gevent库的安装
【命令】: E:\python\Scripts\pip.exe install gevent
3、 flask库的安装
【命令】:E:\python\Scripts\pip.exe install flask
注:如果不知道版本号可以直接安装flask包,系统会安装不同版本的包(不建议使用)
4、 request库的安装
【命令】:E:\python\Scripts\pip.exe install requests==2.18.1
注:安装库的时候若不知道版本号,可以直接输入命令E:\python\Scripts\pip.exe install requests== 从报错信息中查看所有的版本号(建议安装最新的版本)
5、 msgpack-python库的安装
【命令】:E:\python\Scripts\pip.exe install msgpack-python==0.4.8
6、 six库的安装
【命令】:E:\python\Scripts\pip.exe install six==1.11.0
7、 pyzmq库的安装
【命令】:E:\python\Scripts\pip.exe install pyzmq
8、 locust的安装(最后一步)
【命令】:E:\python\Scripts\pip.exe install locustio
脚本编写:根据需求编写好python脚本,放到服务器上如 locust1.py。
脚本运行:通常使用的是主从模式来运行脚本,这样能够方便进程多开。
打开python27目录,输入命令:
cd /d E:\Python27\locust-master
locust -f locust1.py --master
该命令运行后会生成一个主进程进行管理,主进程只需要一个。
locust -f locu.py --slave
该命令运行后会有一个子进程启动,根据需要可以多次运行就会开启多个子进程,子进程用来模拟用户数量。
如果需要多进程就要打开多个窗口开进程:
以上命令运行后或默认开启8089 端口,通过浏览器访问本地8089端口就能进入web界进行控制。
访问地址: http://localhost:8089,slave 就是开启的子进程数量。
如果不同的机器,加后缀主机master的IP:
locust -f ../Python27/load_test1.py --slave --master-host=*ip
3.用户数量的详细解释
web界面的user 数量表示并发数,也就是每次访问的并发连接数。实践的时候用户数量是300,表示每次访问有300个用户同时访问,吞吐量能达到2000/s,说明在一秒的时间内服务器响应了大约7次,那么300的用户耗费的时间就是140ms左右。
4.用户数量与slvae关系
用户数量是300,slave为3,那么每个slave会平均分配发送的用户量100,与jmerter分布式不一样。
五、最终测试结果
服务器配置:CPU 8核 内存16G
承受最大业务量900万次请求数,占用内存12G,占用磁盘空间23G。
redis与业务量关系 80万请求数占用1G redis内存
磁盘与业务量关系 80万请求数占用2G 磁盘空间
附录:
locust -f ../locust-master/load_test.py --master
重新开终端窗口
locust -f ../locust-master/load_test.py --slave
远程链接阿里云服务器
在Win10系统下使用“WIN+R”组合快捷键打开运行对话框,然后输入“mstsc",点击确定
输入服务器IP
QPS: 每秒钟处理完请求的次数;注意这里是处理完。具体是指发出请求到服务器处理完成功返回结果。可以理解在server中有个counter,每处理一个请求加1,1秒后counter=QPS。
TPS:每秒钟处理完的事务次数,一般TPS是对整个系统来讲的。一个应用系统1s能完成多少事务处理,一个事务在分布式处理中,可能会对应多个请求,对于衡量单个接口服务的处理能力,用QPS比较多。
并发量:系统能同时处理的请求数
RT:响应时间,处理一次请求所需要的平均处理时间
计算关系:
QPS = 并发量 / 平均响应时间
并发量 = QPS * 平均响应时间
对比:
测试场景:
对比locust的httpLocust库、python2基础库httplib 和python3基础库http.client的效率和压力
测试接口:通过GET获取URL返回值
Slave机配置:单台8核16G
Slave实例:10个
对比结果:httplocust库RPS最大值4K,python2的最大值12K,python3的最大值15K
Jmeter的TPS最大值是34K
locust的使用的更多相关文章
- 性能测试工具Locust
An open source load testing tool. 一个开源性能测试工具. define user behaviour with python code, and swarm your ...
- python httprequest, locust
r = self.client.get("/orders", headers = {"Cookie": self.get_user_cookie(user[0] ...
- Python Locust对指定网站“一键压测”
[本文出自天外归云的博客园] 前篇 前篇:Python Locust性能测试框架实践 本篇 承上——归纳过程 在前篇的基础上,我们可以利用Locust性能测试框架编写python脚本对指定网站或者接口 ...
- linux安装locust
linux安装locust 1. 安装epel扩展源(目的是为了在安装Pip时不出现一堆乱七八糟的错误信息) EPEL(http://fedoraproject.org/wiki/EPEL) 是由 F ...
- Python Locust性能测试框架实践
[本文出自天外归云的博客园] Locust的介绍 Locust是一个python的性能测试工具,你可以通过写python脚本的方式来对web接口进行负载测试. Locust的安装 首先你要安装pyth ...
- 性能测试框架Locust初学笔记
Locust初探 Locust是一款类似于Jmeter开源负载测试工具,所不同的是它是用python实现,并支持python脚本. locust提供web ui界面,能够方便用户实时监控脚本运行状态. ...
- 初遇locust
大概有四个月没有用过PYTHON的我. 今天差点都不知道怎么运行了. 说起来真是丢人呐. 幸好还是存留着一点点印象,再加上看了一下以前写的几篇文章, 还是比较快的想起来了.不然真的是要崩溃了. 刚开始 ...
- Locust性能测试工具的安装及实际应用
一.安装Locust 安装Locust之前先安装的库:gevent库:第三方库,gevent为python提供了比较完善的协程支持.使用gevent,可以获得极高的并发性能. pip install ...
- Locust性能测试框架,从入门到精通
1. Locust简介 Locust是使用Python语言编写实现的开源性能测试工具,简洁.轻量.高效,并发机制基于gevent协程,可以实现单机模拟生成较高的并发压力. 主要特点如下: 使用普通的P ...
- Locust no-web 模式与参数详解
读前参考:<性能测试工具Locust > 熟悉 Apache ab 工具的同学都知道,它是没有界面的,通过命令行执行. Locust 同样也提供的命令行运行,好处就是更节省客户端资源. 命 ...
随机推荐
- k8s内网安装部署(二)
续上篇 https://www.cnblogs.com/wangql/p/13397034.html 一.kubeadm安装 1.kube-proxy开启ipvs的前置条件 modprobe br_n ...
- [原理] Android Native内存泄漏检测原理解析
转载请注明出处:https://www.cnblogs.com/zzcperf/articles/11615655.html 上一篇文章列举了不同版本Android OS内存泄漏的检测操作(传送门), ...
- 网骗欺诈?网络裸奔?都是因为 HTTP?
先跟大家讲个故事,我初恋是在初中时谈的,我的后桌的后桌.那个时候没有手机这类的沟通工具,上课交流有三宝,脚踢屁股.笔戳后背以及传纸条,当然我只能是那个屁股和后背,还不是能让初恋踢到的后背. 但是说实话 ...
- 【GDKOI2014】JZOJ2020年8月13日提高组T2 石油储备计划
[GDKOI2014]JZOJ2020年8月13日提高组T2 石油储备计划 题目 Description Input Output 对于每组数据,输出一个整数,表示达到"平衡"状态 ...
- Python中的enumerate函数的作用
enumerate函数是将一个可迭代对象中元素,按元素顺序每个增加一个索引值,将其组成一个索引序列,利用它可以同时获得索引和值,这样做的目的是为了将一个可迭代对象中元素组成一个"索引,值&q ...
- 第二十五章、containers容器类部件GroupBox分组框详解
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 一.概述 容器部件就是可以在部件内放置其他部件的部件,在Qt Designer中可以使用的容器部件有 ...
- 使用文件描述符作为Python内置函数open的file实参调用示例
一.关于文件描述符 open()函数的file参数,除了可以接受字符串路径外,还可以接受文件描述符(file descriptor),文件描述符是个整数,对应程序中已经打开的文件. 文件描述符是操作系 ...
- ollvm在VS2017下编译
0x1,首先介绍一下编译环境配置 1.UE4.25 2.vs2017(15.9),注:2019编译总是出现错误 3.cmake3.18.5,cmake的作用是为ollvm源码编译成适合于在vs2017 ...
- [GKCTF2020]CheckIN 注意了解多方面的东西
打开之后是这样的,没有发现反序列化函数,但是发现有一个@eval,想到了一句话,这是用base64进行传参首先传参phpinfo();看看,需要经过base64编码 http://e0cc90ac-d ...
- 函数与函数式编程(生成器 && 列表解析 && map函数 && filter函数)-(四)
在学习python的过程中,无意中看到了函数式编程.在了解的过程中,明白了函数与函数式的区别,函数式编程的几种方式. 函数定义:函数是逻辑结构化和过程化的一种编程方法. 过程定义:过程就是简单特殊没有 ...