性能测试十八:jmeter分布式
一台压力机产生得压力是有限的,尤其是jmeter,java本来性能就不是很好,并发特别多的时候,jmeter的性能会急剧下降,正常的接口,若单台压力机,超过1000并发以后,jmeter的性能就不怎么行了 所以需要多个压力机,即多个机器部署jmeter产生压力
分布式测试步骤:
系统HOSTS文件中进行类似 本机IP 主机名的配置
如10.0.0.23 zhoucentos,否则启动jmeter server会报错!
1,在每台机器上都部署 jmeter
2,如果是java脚本,将java脚本和相关lib包都放在jmeter目录lib/ext下
3,将jmeter的场景文件jmx上传到服务器上的任意位置,jmx只放在主压力机上即可,如果有参数文件,需将参数文件放到所有压力机与主压力机的相同目录下
4,在每台机器上进入到jmeter的bin目录下,都启动nohup ./jmeter-server &(后台启动jmeter-server服务)
5,进入到jmeter目录下,将两台机器上的jmeter下所有文件都赋予可执行权限,chmod -R +x ./*
6,在主jmeter的bin目录下,修改jmeter.properties,将其中的remote_hosts修改为作为压力机的两台机器ip,remote_hosts=127.0.0.1,192.168.0.102?
7,在主jmeter的机器上,执行/export/servers/apache-jmeter-xxx/bin/jmeter -n -t jdbc.jmx -l result -jtl -r(示例,具体目录和路径自定义)
关键步骤:
1,如果是http脚本,在controller的机器上有脚本文件即可;
如果是Java脚本,在每一台机器上都得有脚本文件和依赖的jar包
2,进到Jmeter 根目录下需要添加执行权限 chmod -R +x ./*
以我的虚拟机为例:
先正常关闭虚拟机
liunx虚拟机上右键复制,勾选重新初始化mac地址,完全复制
然后都启动,用Xshell连接,若副本没有ip则自己去配置一下,参考Xshell连接liunx
系统HOSTS文件中进行类似 本机IP 主机名的配置: vi /etc/hosts 每台机器都要配
1···、
2···、
3···
4、在每台机器上进入到jmeter的bin目录下,都启动nohup ./jmeter-server &(后台启动jmeter-server服务)
启动server
第一种方式:阻塞式的启动,即启动成功后不允许退出,若退出则关闭此jmeter服务进程 ,想做其他动作就只能复制一个ssh渠道,不建议用此方法
若这一步报未知的主机XXX,就是hosts里面的ip和名字没配好
第二种方式:以后台的方式启动nohup ./jmeter-server & (此方式因为是后台挂起,所以看不到是否有报错)
把要后台启动的程序放在nohup和&之间即可
nohup:非挂起的意思,nohup可以把任何文件都以后台的形式启动
此时再敲一下回车即可,输入 ps -ef|grep jmeter-server 查看此进程
所有机器都要启动jmeter-server
!ps即可执行最近一次执行的ps命令
5、进入到jmeter目录下,将两台机器上的jmeter下所有文件都赋予可执行权限,chmod -R +x ./*
-R:如果当前赋予权限的文件夹下还有文件夹,则把下面的文件夹也赋予权限
6、在主jmeter的bin目录下,修改jmeter.properties,将其中的remote_hosts修改为作为压力机的两台机器ip,remote_hosts=127.0.0.1,192.168.0.102?
vi jmeter.properties
7、在主jmeter的机器上,执行/export/servers/apache-jmeter-xxx/bin/jmeter -n -t jdbc.jmx -l result -jtl -r(示例,具体目录和路径自定义)
启动要被压测的服务器上的tomcat
回到存放jmx脚本的目录下
查看脚本配置项有没有问题,有就修改
根据HTTPS查找到请求的内容
由于是多机运行此脚本,如果ip是localhost的话,相当于是所有jmeter压力机自己压自己,所以需将ip改为被压服务器的ip
此时先别着急执行多机压测,先看一下单机压测是否成功,如果单机压测都失败,那么多机压测也一定会失败
错误率0,此时可以ctrl+c停止单机压测,并开始多机压测
第一种方式:执行命令:jmeter -n -t time.jmx -l time.jtl -r
-r:jmeter运行时读取到-r,就会去配置文件中读取里面的ip,并将读取到的ip下的jmeter全部运行
之前处理结果报告的方式一样可以处理此结果报告
第二种方式:执行命令 jmeter -n -t time.jmx -l time.jtl -R ip1,ip2
jmeter读取到-R,不回去读取配置文件里面的ip,会读取R后面跟的ip,并启动
此方法不建议,如果机器多的话,命令会非常长
如果此处提示tobusy,则需要将tomcat-server重新启动一下,全部重新起一下
如,多机压测未完成,就Ctrl+c强制停止,此时其他机器还在跑,这个时候再次运行多机压测脚本,就会tobusy
重启jmeter-server:先kill掉进程,再启动
先执行 ps -ef|grep jmeter-server 找到jmeter-server的进程
执行:kil -9 端口号,强制关闭
然后在去启动jmeter-server
性能测试十八:jmeter分布式的更多相关文章
- Spark学习之路 (二十八)分布式图计算系统
一.引言 在了解GraphX之前,需要先了解关于通用的分布式图计算框架的两个常见问题:图存储模式和图计算模式. 二.图存储模式 巨型图的存储总体上有边分割和点分割两种存储方式.2013年,GraphL ...
- 三十八 Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)介绍以及安装
elasticsearch(搜索引擎)介绍 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.Elasticse ...
- Spark学习之路 (二十八)分布式图计算系统[转]
引言 在了解GraphX之前,需要先了解关于通用的分布式图计算框架的两个常见问题:图存储模式和图计算模式. 图存储模式 巨型图的存储总体上有边分割和点分割两种存储方式.2013年,GraphLab2. ...
- 性能测试十:jmeter进阶之webService与socket
一.webService 1.添加http post请求2.添加header:Conent-type:text/xml Post请求的body中填写<soapenv:Envelope xmln ...
- 二十八 Python分布式爬虫打造搜索引擎Scrapy精讲—cookie禁用、自动限速、自定义spider的settings,对抗反爬机制
cookie禁用 就是在Scrapy的配置文件settings.py里禁用掉cookie禁用,可以防止被通过cookie禁用识别到是爬虫,注意,只适用于不需要登录的网页,cookie禁用后是无法登录的 ...
- 十八 Python分布式爬虫打造搜索引擎Scrapy精讲—Scrapy启动文件的配置—xpath表达式
我们自定义一个main.py来作为启动文件 main.py #!/usr/bin/env python # -*- coding:utf8 -*- from scrapy.cmdline import ...
- 四十八 Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)用Django实现搜索功能
Django实现搜索功能 1.在Django配置搜索结果页的路由映射 """pachong URL Configuration The `urlpatterns` lis ...
- Jmeter分布式部署测试-----远程连接多台电脑做压力性能测试
在使用Jmeter进行接口的性能测试时,由于Jmeter 是JAVA应用,对于CPU和内存的消耗比较大,所以,当需要模拟数以万计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心,甚至会引起J ...
- 【转载】Jmeter分布式部署测试-----远程连接多台电脑做压力性能测试
在使用Jmeter进行接口的性能测试时,由于Jmeter 是JAVA应用,对于CPU和内存的消耗比较大,所以,当需要模拟数以万计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心,甚至会引起J ...
随机推荐
- JQ版本对比
JQ不知不觉来到第三版了,那么它们有什么不同呢? 下面先给大家推一个CDN加速的网站,上面有各种JQ的版本:http://www.bootcdn.cn/jquery/ 先来对比一下它们的“体重”,23 ...
- 使用swagger来编写在线api文档
swagger是一个非常简单,强大的框架.快速上手,只需要引入jar包 , 使用注解就可以生成一个漂亮的在线api文档 pom.xml <dependency> <groupId&g ...
- idea创建多模块springboot项目
需求:一个父模块 下面几个子模块 其中一个模块是springboot结构.其他两个普通jar类型 有许多坑,都在注释里面写着呢.注意看父模块和demo模块的注释. com.imooc.securi ...
- 使用jQuery实现返回顶部功能
<p id="back-to-top"><a href="#top"><span></span>返回顶部< ...
- 前段clam安装
前端模块化协同开发解决方案 —— clam 1. 打开后直接看最后一条https://blog.csdn.net/zhangwenwu2/article/details/581720422. node ...
- luogu P4289 [HAOI2008]移动玩具
传送门 这道题可以二进制记录状态搜索 也可以做以下考虑 若一个棋子要移动到另一个位置上去,则步数为两点的曼哈顿距离(横坐标差的绝对值+纵坐标差的绝对值),因为假设路径上有其他的棋子,可以通过移动其他棋 ...
- Servlet.service() for servlet jsp threw exception
报错信息如下: org.apache.catalina.core.ApplicationDispatcher invoke 严重: Servlet.service() for servlet jsp ...
- php 获取压缩包名
参考链接: https://segmentfault.com/q/1010000000721799 通过curl方式获取压缩包名: function getFile($url, $save_dir = ...
- python安装模块方法汇总
方法一: 原文地址: http://blog.csdn.net/cighao/article/details/47860041 在 windows 系统下,只需要输入命令 pip install re ...
- B. Light It Up
题目链接:http://codeforces.com/problemset/problem/1000/B 代码: #include<iostream> #include<cstrin ...