性能测试十八: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 ...
随机推荐
- 关于mysql数据库优化
关于mysql数据库优化 以我之愚见,数据库的优化在于优化存储和查询速度 目前主要的优化我认为是优化查询速度,查询速度快了,提高了用户的体验 我认为优化主要从两方面进行考虑, 优化数据库对象, 优化s ...
- django在读取数据库时未筛选到符合条件的记录会报错
(1)报错情况如下: DoesNotExist: Publisher matching query does not exist. (2)处理方法: try: p = Publisher.o ...
- python3写入文件时编码问题报错
在字符串写入文件时,有时会因编码问题导致无法写入,可在open方法中指定encoding参数 chfile = open(filename, 'w', encoding='utf-8') 这样可解决大 ...
- 5、Python-字典
定义 info = {'name': '班长', 'id': 88, 'sex': 'man', 'address': '地球亚洲中国北京'} print(info['name']) print(in ...
- Study 7 —— while循环中止语句
循环的终止语句break #用于完全结束一个循环,跳出循环体执行循环后面的语句continue #只终止本次循环,接着执行后面的循环 1. 打印0-100,截止到第6次 count = 0 while ...
- A + B,末k位不相同
题目描述 读入两个小于10000的正整数A和B,计算A+B.需要注意的是:如果A和B的末尾K(不超过8)位数字相同,请直接输出-1. 输入描述: 测试输入包含若干测试用例,每个测试用例占一行,格式为& ...
- AsciiMorph - 新奇的 ASCII 字符画生成工具&插件
AsciiMorph 是一个新奇的 ASCII 字符画生成工具和开源插件.字符画(ASCII Art)的历史可以追溯到几十年前,起初是用在图形显示功能受限的设备上,用ASCII字符集里的可打印字符来拼 ...
- windows 查看链接数
windows 端口链接数 查看有效 链接数: netstat -an|find " |find "ESTABLISHED" /c /c 统计: 查看链接信息: 查看当 ...
- luogu P2303 [SDOi2012]Longge的问题
传送门 \[\sum_{i=1}^{n}\gcd(i,n)\] 考虑枚举所有可能的gcd,可以发现这一定是\(n\)的约数,当\(\gcd(i,n)=x\)时,\(gcd(\frac{i}{x},\f ...
- Maven继承
继承为了消除重复,可以把pom 中很多相同的配置提取出来:如:grouptId, version 等. 在使用的时候子工程直接继承父工程的依赖版本号,子工程中不再需要指定具体版本号,方便统一管控项目的 ...