章节一压力测试课程介绍

1、2018年亿级流量压测系列之Jmeter4.0课程介绍和效果演示

简介:
讲解课程安排,使用的Jmeter版本

讲课风格:涉及的组件,操作配置多,不会一次性讲解,会先讲部分,然后在后续操作中慢慢补充,更容易消化和理解

2、常用压力测试工具对比
简介:目前用的常用测试工具对比
1、loadrunner
性能稳定,压测结果及细粒度大,可以自定义脚本进行压测,但是太过于重大,功能比较繁多

2、apache ab(单接口压测最方便)
模拟多线程并发请求,ab命令对发出负载的计算机要求很低,既不会占用很多CPU,也不会占用太多的内存,但却会给目标服务器造成巨大的负载, 简单DDOS攻击等

3、webbench
webbench首先fork出多个子进程,每个子进程都循环做web访问测试。子进程把访问的结果通过pipe告诉父进程,父进程做最终的统计结果。

章节二 JMeter4.x基础知识讲解和压测实操

3、Jmeter基本介绍和使用场景
简介
1、压测不同的协议和应用
1) Web - HTTP, HTTPS (Java, NodeJS, PHP, ASP.NET, …)
2) SOAP / REST Webservices
3) FTP
4) Database via JDBC
5) LDAP 轻量目录访问协议
6) Message-oriented middleware (MOM) via JMS
7) Mail - SMTP(S), POP3(S) and IMAP(S)
8) TCP等等

2、使用场景及优点
1)功能测试
2)压力测试
3)分布式压力测试
4)纯java开发
5)上手容易,高性能
4)提供测试数据分析
5)各种报表数据图形展示

4、本地快速安装Jmeter4.x
简介:GUI图形界面的安装
1、需要安装JDK8。或者JDK9,JDK10
2、快速下载
windows: http://mirrors.tuna.tsinghua.edu.cn/apache//jmeter/binaries/apache-jmeter-4.0.zip
mac或者linux:http://mirrors.tuna.tsinghua.edu.cn/apache//jmeter/binaries/apache-jmeter-4.0.tgz

3、文档地址:http://jmeter.apache.org/usermanual/get-started.html

4、建议安装JDK环境,虽然JRE也可以,但是压测https需要JDK里面的 keytool工具

5、Jmeter目录文件讲解
简介:讲解jmeter解压文件里面的各个目录,文件等
1、目录
bin:核心可执行文件,包含配置
jmeter.bat: windows启动文件:
jmeter: mac或者linux启动文件:
jmeter-server:mac或者Liunx分布式压测使用的启动文件
jmeter-server.bat:mac或者Liunx分布式压测使用的启动文件
jmeter.properties: 核心配置文件

extras:插件拓展的包
lib:核心的依赖包
ext:核心包
junit:单元测试包

6、Jmeter语言版本中英文切换
简介:
讲解怎么改变jmeter的GUI界面语言版本
1、控制台修改
menu -> options -> choose language
2、配置文件修改
bin目录 -> jmeter.properties
默认 #language=en
改为 language=zh_CN

7、使用SpringBoot 2.0快速编写API测试接口

简介
使用java的框架springBoot快速编写几个API接口测试

https://spring.io/guides/gs/spring-boot/

接口列表
1、模拟GET请求,用户列表接口
2、模拟POST请求,用户登录接口

http://localhost:8080/users

8、创建Jmeter测试计划,快速压测一个接口
简介:
通过带着why来学习,快速创建一个测试计划

章节三 Jmeter核心组件讲解和实操

9、Jmeter基础功能组件介绍线程组和Sampler
简介:讲解Jmeter里面GUI菜单栏主要组件

1、添加->threads->线程组(控制总体并发)
线程数:虚拟用户数。一个虚拟用户占用一个进程或线程

准备时长(Ramp-Up Period(in seconds)):全部线程启动的时长,比如100个线程,20秒,则表示20秒内100个线程都要启动完成,每秒启动5个线程

循环次数:每个线程发送的次数,假如值为5,100个线程,则会发送500次请求,可以勾选永远循环

2、线程组->添加-> Sampler(采样器) -> Http (一个线程组下面可以增加几个Sampler)
名称:采样器名称
注释:对这个采样器的描述

web服务器:
默认协议是http
默认端口是80
服务器名称或IP :请求的目标服务器名称或IP地址

路径:服务器URL

Use multipart/from-data for HTTP POST :当发送POST请求时,使用Use multipart/from-data方法发送,默认不选中。

3、查看测试结果
线程组->添加->监听器->察看结果树

10、Jmeter的断言基本使用
简介:介绍什么是断言及基本使用

1、增加断言: 线程组 -> 添加 -> 断言 -> 响应断言

apply to(应用范围):
Main sample only: 仅当前父取样器 进行断言,一般一个请求,如果发一个请求会触发多个,则就有sub sample(比较少用)
要测试的响应字段:
响应文本:即响应的数据,比如json等文本
响应代码:http的响应状态码,比如200,302,404这些
响应信息:http响应代码对应的响应信息,例如:OK, Found
Response Header: 响应头
模式匹配规则:
包括:包含在里面就成功
匹配:响应内容完全匹配,不区分大小写
equals:完全匹配,区分大小写

2、断言结果监听器: 线程组-> 添加 -> 监听器 -> 断言结果
里面的内容是sampler采样器的名称
断言失败,查看结果树任务结果颜色标红(通过结果数里面双击不通过的记录,可以看到错误信息)

3、每个sample下面可以加单独的结果树,然后同时加多个断言,最外层可以加个结果树进行汇总

11、Jmeter实战之压测结果聚合报告分析
简介:讲解压测结果的聚合报告

新增聚合报告:线程组->添加->监听器->聚合报告(Aggregate Report)

lable: sampler的名称
Samples: 一共发出去多少请求,例如10个用户,循环10次,则是 100
Average: 平均响应时间
Median: 中位数,也就是 50% 用户的响应时间

90% Line : 90% 用户的响应不会超过该时间 (90% of the samples took no more than this time. The remaining samples at least as long as this)
95% Line : 95% 用户的响应不会超过该时间
99% Line : 99% 用户的响应不会超过该时间
min : 最小响应时间
max : 最大响应时间

Error%:错误的请求的数量/请求的总数
Throughput: 吞吐量——默认情况下表示每秒完成的请求数(Request per Second) 可类比为QPS
KB/Sec: 每秒接收数据量

12、Jmeter压测脚本JMX讲解
简介:压测脚本JMX讲解
1、打开方式subline,或者xml编辑器
2、运行日志和压测时间查看(基础按钮)

章节四 自定义变量和CSV可变参数实操

13、Jmeter用户自定义变量实战

简介:什么是用户自定义变量,怎样使用

为什么使用:很多变量在全局中都有使用,或者测试数据更改,可以在一处定义,四处使用
比如服务器地址

1、线程组->add -> Config Element(配置原件)-> User Definde Variable(用户定义的变量)

2、引用方式${XXX},在接口中变量中使用

3、原始查看结果树和非原生查看(基础按钮)

14、Jmeter实战之CSV可变参数压测
简介:
实战操作jmeter读取CSV和Txt文本文件里面的参数进行压测
1、线程组->add -> Config Element(配置原件)-> CSV data set config (CSV数据文件设置)

Jmeter读取excel表资料:https://www.cnblogs.com/amberdyy/p/8434776.html

15、CSV文件多参数使用
简介:在读取的配置文件里面,同时使用多个自定义参数

1、如果是多个参数需要同时引用,则在CSV数据文件里面设置加多个字段
Variabled names(comma-delitited): csv_name,csv_pwd

章节五 Mysql数据库压测实操

16、Jmeter压测实战之JDBC request压测Mysql讲解
简介:讲解jdbc压测mysql相关准备工作,jar包添加,配置讲解
1、Thread Group -> add -> sampler -> jdbc request
2、jar包添加 mysql-connector-java-5.1.30.jar

3、JDBC connection Configuration 配置
1、JDBC request->add -> config element -> JDBC connection configuration
核心配置
Max Number of connections : 最大连接数
MAX wait :最大等待时间
Auto Commit: 是否自动提交事务

DataBase URL : 数据库连接地址 jdbc:mysql://127.0.0.1:3306/blog
JDBC Driver Class : 数据库驱动,选择对应的mysql
username:数据库用户名
password:数据库密码

17、Jmeter压测实战之JDBC request压测Mysql, select语句
简介:使用jmeter压测mysql,select,insert语句
1、Debug Sampler使用(结果树中查看)
Thread Group -> add -> sampler -> debug sampler

2、参数讲解:(sql结尾不要加";")
1、variable name of pool declared in JDBC connection configuration(和配置文件同名)
2、Query Type 查询类型
3、parameter values 参数值
4、parameter types 参数类型
5、variable names sql执行结果变量名
6、result variable names 所有结果当做一个对象存储
7、query timeouts 查询超时时间
8、 handle results 处理结果集

章节六 高级篇之分布式压测基础知识

18、分布式压测介绍
简介:讲解什么是分布式压测

普通压测:单台机可以对目标机器产生的压力比较小,受限因素包括CPU,网络,IO等
分布式压测:利用多台机器向目标机器产生压力,模拟几万用户并发访问

19、Jmeter分布式压测原理
简介:讲解Jmeter分布式压测原理
1、总控机器的节点master,其他产生压力的机器叫“肉鸡” server
2、master会把压测脚本发送到 server上面

3、执行的时候,server上只需要把jmeter-server打开就可以了,不用启动jmeter
4、结束后,server会把压测数据回传给master,然后master汇总输出报告
5、配置详情

章节七 高级篇之阿里云Linux服务器压测接口实战

20、SpringBoot 接口打包,并用jar包方式部署
简介:用jar包方式在控制台进行启动
打包 mvn package && java -jar target/gs-spring-boot-0.1.0.jar

21、阿里云服务器介绍和ECS服务器使用
简介:
阿里云服务器介绍和购买ECS服务器等

推荐购买2G内存以上的进行开发学习

22、阿里云Linux服务器下安装启动JDK8并配置环境变量
简介:在阿里云环境下安装JDK8并配置环境变量

23、部署java项目到阿里云服务器和守护进程讲解

简介:
部署项目到阿里云,并启动,公网可以访问
1、注意点
关闭防火墙
阿里云控制台安全策略,开放端口
linux上运行 java -jar xxxx

ssh root@120.79.160.143

守护进程:nohup java -jar xxxxx &
什么是守护进程:

24、阿里云Linux服务器安装Jmeter 4.0
简介:在阿里云环境下安装Jmeter

经济足够:购买两台阿里云机器
不足:本地虚拟机,或者用你室友的电脑,在同个局域网就可以,安装同个版本的jdk,jmeter,同个路径,不要带有空格或者中文

下载地址
wget http:/apache.osuosl.org/jmeter/binaries/apache-jmeter-4.0.tgz
wget http://apache.osuosl.org/jmeter/binaries/apache-jmeter-5.1.tgz
http://apache.osuosl.org/jmeter/binaries/apache-jmeter-5.1.tgz

25、Jmeter非GUI界面 参数讲解
讲解:非GUI界面,压测参数讲解
-h 帮助
-n 非GUI模式
-t 指定要运行的 JMeter 测试脚本文件
-l 记录结果的文件 每次运行之前,(要确保之前没有运行过,即xxx.jtl不存在,不然报错)
-r Jmter.properties文件中指定的所有远程服务器
-e 在脚本运行结束后生成html报告
-o 用于存放html报告的目录(目录要为空,不然报错)

官方配置文件地址 http://jmeter.apache.org/usermanual/get-started.html

/usr/local/temp

jmeter -n -t linux_users_api.jmx -l result.jtl -e -o /usr/local/softwate/jmeter/temp/ResultReport
短信平台:./jmeter -n -t /usr/local/temp/jmx/APS_send.jmx -r -l /usr/local/temp/result/result_20190729/result.jtl -e -o /usr/local/temp/report
jmeter -n -t /Users/jack/Desktop/linux_users_api.jmx -l result.jtl -e -o /Users/jack/Desktop/person/jmeter/temp

26、项目实战之阿里云Linux服务器下非GUI执行jmeter压测
简介:
在阿里云服务器上以非GUI界面去执行JMX压测脚本

jmx目录:/usr/local/software/jmeter/temp

jmeter -n -t /usr/local/software/jmeter/temp/linux_users_api.jmx -l /usr/local/software/jmeter/temp/jtl/result.jtl

章节八 高级篇之阿里云压测 html可视化压测报告细讲

27、阿里云Linux服务器 Jmeter压测实战之jtl文件生成和查看
简介:
利用软件从阿里云Centos服务器下载压测报告,讲解Jtl文件,并怎么查看文件
可以通过打开jmeter,新建线程组->summary report->浏览文件 进行查看

28、Jmeter压测接口的性能优化

简介:讲解Jmeter压测减少资源使用的一些建议,即压测结果更准确

1、使用非GUI模式:jmeter -n -t test.jmx -l result.jtl

2、少使用Listener, 如果使用-l参数,它们都可以被删除或禁用。
3、在加载测试期间不要使用“查看结果树”或“查看结果”表监听器,只能在脚本阶段使用它们来调试脚本。

4、包含控制器在这里没有帮助,因为它将文件中的所有测试元素添加到测试计划中。
5、不要使用功能模式,使用CSV输出而不是XML
6、只保存你需要的数据,尽可能少地使用断言

7、如果测试需要大量数据,可以提前准备好测试数据放到数据文件中,以CSV Read方式读取。
8、用内网压测,减少其他带宽影响压测结果
9、如果压测大流量,尽量用多几个节点以非GUI模式向服务器施压

官方推荐 :http://jakarta.apache.org/jmeter/usermanual/best-practices.html#lean_mean

29、项目实战之Jmeter压测生成多维度图形化HTML测试报告
简介:
把Jmtere压测结果转换为Html

指令
jmeter -n -t /usr/local/software/jmeter/temp/linux_users_api.jmx -l /usr/local/software/jmeter/temp/jtl/result.jtl -e -o /usr/local/software/jmeter/temp/result

30、Jmeter图形化HTML压测报告dashboard讲解
简介:
讲解压测报告 html里面Dashboard的核心指标
1、dashboard讲解
1)Test and Report informations
Source file:jtl文件名
Start Time :压测开始时间
End Time :压测结束时间
Filter for display:过滤器
Lable:sampler采样器名称

2)APDEX(Application performance Index)
apdex:应用程序性能指标,范围在0~1之间,1表示达到所有用户均满意
T(Toleration threshold):可接受阀值
F(Frustration threshold):失败阀值

3)Requests Summary
OK:成功率
KO:失败率
4)Statistics 统计数据
lable:sampler采样器名称

samples:请求总数,并发数*循环次数
KO:失败次数
Error%:失败率

Average:平均响应时间
Min:最小响应时间
Max:最大响应时间
90th pct: 90%的用户响应时间不会超过这个值(关注这个就可以了)
2ms,3ms,4,5,2,6,8,3,9

95th pct: 95%的用户响应时间不会超过这个值
99th pct: 99%的用户响应时间不会超过这个值 (存在极端值)
throughtput:Request per Second吞吐量 QPS

received:每秒从服务器接收的数据量
send:每秒发送的数据量

31、Jmeter图形化HTML压测报告Charts报表讲解
简介:
讲解压测报告 html里面Charts的核心指标
1、charts讲解
1)Over Time(随着时间的变化)
Response Times Over Time:响应时间变化趋势
Response Time Percentiles Over Time (successful responses):最大,最小,平均,用户响应时间分布
Active Threads Over Time:并发用户数趋势
Bytes Throughput Over Time:每秒接收和请求字节数变化,蓝色表示发送,黄色表示接受
Latencies Over Time:平均响应延时趋势
Connect Time Over Time :连接耗时趋势

1)Throughput
Hits Per Second (excluding embedded resources):每秒点击次数
Codes Per Second (excluding embedded resources):每秒状态码数量
Transactions Per Second:即TPS,每秒事务数
Response Time Vs Request:响应时间和请求数对比
Latency Vs Request:延迟时间和请求数对比

1)Response Times
Response Time Percentiles:响应时间百分比
Response Time Overview:响应时间概述
Time Vs Threads:活跃线程数和响应时间
Response Time Distribution:响应时间分布图

需要重点关注的指标:Response Times Over Time:响应时间变化趋势、Codes Per Second (excluding embedded resources):每秒状态码数量、Response Time Percentiles:响应时间百分比

章节九 高级篇之多节点JMeter分布式压测实战

32、Jmeter4.0分布式压测准备工作

简介:讲解Linux服务器上jmeter进行分布式压测的相关准备工作

1、压测注意事项
the firewalls on the systems are turned off or correct ports are opened.
系统上的防火墙被关闭或正确的端口被打开。

all the clients are on the same subnet.
所有的客户端都在同一个子网上。

the server is in the same subnet, if 192.x.x.x or 10.x.x.x IP addresses are used. If the server doesn't use 192.xx or 10.xx IP address, there shouldn't be any problems.
如果使用192.x.x.x或10.x.x.x IP地址,则服务器位于同一子网中。 如果服务器不使用192.xx或10.xx IP地址,则不应该有任何问题。

Make sure JMeter can access the server.
确保JMeter可以访问服务器。

Make sure you use the same version of JMeter and Java on all the systems. Mixing versions will not work correctly.
确保在所有系统上使用相同版本的JMeter和Java。 混合版本将无法正常工作。

You have setup SSL for RMI or disabled it.
您已为RMI设置SSL或将其禁用。

官网地址 http://jmeter.apache.org/usermanual/jmeter_distributed_testing_step_by_step.html

压测注意事项:一定要用内网IP,不用用公网IP,用ping去检查

2、专业名字
master:司令
slave:奴隶
target:目标

地址:http://jmeter.apache.org/images/screenshots/distributed-names.svg
地址:http://jmeter.apache.org/images/screenshots/distributed-jmeter.svg

远程拷贝(内网地址):
scp -r /usr/local/software/jdk-8u141-linux-x64.tar.gz root@172.18.230.233:/usr/local/software
scp -r /usr/local/software/jmeter/apache-jmeter-4.0.tgz root@172.18.230.233:/usr/local/software/jmeter

解压:tar -zxvf 文件名

启动
./jmeter-server 或者 nohup ./jmeter-server &

检查启动是否成功
ps -ef|grep jmeter-server
ps aux|grep jmeter-server

33、阿里云jmeter压测常见问题处理
简介:讲解阿里云上安装jmeter常见问题的处理,安装遇到的问题等等

34、Jmeter4.0分布式压测实战
简介:Jmeter分布式压测实战,压测接口

1、关注CPU和内存使用

本地非GUI分布式压测 -r
jmeter -n -t /Users/jack/Desktop/remote.jmx -r -l /Users/jack/Desktop/jtl/result.jtl -e -o /Users/jack/Desktop/result

压测结果
./jmeter -n -t /Users/jack/Desktop/remote.jmx -r -l /Users/jack/Desktop/jtl/result.jtl -e -o /Users/jack/Desktop/result

Creating summariser <summary>
Created the tree successfully using /Users/jack/Desktop/remote.jmx
Configuring remote engine: 172.20.10.3:8899
Using local port: 8899
Configuring remote engine: 172.20.10.11:8899
Starting remote engines
Starting the test @ Thu Mar 29 23:21:13 CST 2018 (1522336873931)
Remote engines have been started
Waiting for possible Shutdown/StopTestNow/Heapdump message on port 4445
summary = 4 in 00:00:22 = 0.2/s Avg: 5582 Min: 94 Max: 21006 Err: 1 (25.00%)
Tidying up remote @ Thu Mar 29 23:21:36 CST 2018 (1522336896842)
... end of run

summary + 115602 in 00:00:24(开始时间) = 4744.8/s Avg: 8(平均响应时间) Min: 1 (最小响应时间)Max: 355(最大响应时间) Err: 0 (错误数)(0.00%) Active: 40(40个并发) Started: 4040(启动40个并发) Finished: 0

2、压测修改master节点信息
jemeter.properties 值是slave机器的ip+端口号,如果有多个,用逗号分隔
remote_hosts=192.168.0.102:8899,192.168.0.101:8899
server.rmi.ssl.disable=true (前面有说到)

3、启动slave机器,注意要同个网段,ip地址用内网ip
./jmeter-server
jmeter.properties 修改如下配置:server_port:8899 server.rmi.localport=8899

端口被占用:lsof -i tcp:9090

Using local port: 8899
Created remote object: UnicastServerRef2 [liveRef: [endpoint:[192.168.0.102:8899](local),objID:[3a585a4d:162724586ab:-7fff, 3963132813614033916]]]

相关资料:
https://www.cnblogs.com/Fine-Chan/p/6233823.html
https://blog.csdn.net/liujingqiu/article/details/52635289
https://www.cnblogs.com/puresoul/p/4844539.html

nmon 生成报告文件:
-f 参数:生成文件,文件名=主机名+当前时间.nmon
-T 参数:显示资源占有率较高的进程
-s 参数:-s 10表示每隔10秒采集一次数据
-c 参数:-s 10表示总共采集十次数据
-m 参数:指定文件保存目录
nmon -f -T -s 5 -c 12 /usr/local/cpu_result
nmon -f -T -s 5 /usr/local/cpu_result
执行:./jmeter -n -t /usr/local/temp/jmx/APS_send.jmx -r -l /usr/local/temp/result/result_25_1/result.jtl -e -o /usr/local/temp/report/report_25_1

章节十 高级篇之Jmeter压测课程总结和架构浅析

35、课程总结和关于系统架构,推荐学习资料
简介:讲解测试人员的基础技能,系统架构知识,相关推荐书籍,课程总结等

配置元件=》前置处理器=》定时器=》采样器=》后置处理器=》断言=》监听器

安装常见问题
1、问题
[root@iZwz95j86y235aroi85ht0Z bin]# ./jmeter-server
Created remote object: UnicastServerRef2 [liveRef: [endpoint:[:39308](local),objID:[24e78a63:16243c70661:-7fff, 7492480871343944173]]]
Server failed to start: java.rmi.RemoteException: Cannot start. Unable to get local host IP address.; nested exception is:
java.net.UnknownHostException: iZwz95j86y235aroi85ht0Z: iZwz95j86y235aroi85ht0Z: Name or service not known
An error occurred: Cannot start. Unable to get local host IP address.; nested exception is:
java.net.UnknownHostException: iZwz95j86y235aroi85ht0Z: iZwz95j86y235aroi85ht0Z: Name or service not known

解决:
hostname 命令获取机器名称,追加一个映射 iZwz95j86y235aroi85ht0Z
vim /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
120.79.160.143 iZwz95j86y235aroi85ht0Z

windows用户 修改c:\windows\system32\drivers\etc\hosts文件,增加一条域名 与IP的映射

2、问题
[root@iZwz95j86y235aroi85ht0Z bin]# ./jmeter-server
Server failed to start: java.rmi.server.ExportException: Listen failed on port: 0; nested exception is:
java.io.FileNotFoundException: rmi_keystore.jks (No such file or directory)
An error occurred: Listen failed on port: 0; nested exception is:
java.io.FileNotFoundException: rmi_keystore.jks (No such file or directory)
解决:
拥有RMI over SSL的有效密钥库,或者禁用了SSL。
1、禁用SSL
jmeter.property里面 server.rmi.ssl.disable 改为 true,表示禁用

3、问题:
[root@iZ949uw2xehZ bin]# ./jmeter
Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000c0000000, 1073741824, 0) failed; error='Cannot allocate memory' (errno=12)
#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (mmap) failed to map 1073741824 bytes for committing reserved memory.
# An error report file with more information is saved as:
# /usr/local/jmeter/apache-jmeter-4.0/bin/hs_err_pid5855.log

解决:
编辑jmeter
搜索 : "${HEAP:="-Xms1g -Xmx1g -XX:MaxMetaspaceSize=256m"}"
改变初始堆内存和最大堆内存
可以修改为: "${HEAP:="-Xms124m -Xmx124m -XX:MaxMetaspaceSize=256m"}"

4、仅修改 server_port 即可,下面两者一样
server.rmi.localport=8899 表示slave server启动显示的端口
server_port=8899 表示master机器要远程连接的端口 即 remote_hosts=xxxx:8899

5、
<!-- jmeter 分布式性能测试(多网卡配置) -->
我们要在多网卡的服务器上开启RMI服务的话必须指定IP,使他们能够在同一个网段内。

需要以下几步(假定所有机器都在10.120.11.*网段,agent服务器为linux,controller服务器为windows):

1、 修改agent服务器,指定agent机器的IP
修改jmeter-server文件
# vi jmeter-server
修改RMI_HOST_DEF=-Djava.rmi.server.hostname=xxx.xxx.xxx.xxx(需要连接的IP)

2、修改server服务器,指定server机器的IP

修改jmeter.bat文件

新增set rmi_host=-Djava.rmi.server.hostname=10.120.11.214

修改set ARGS=%DUMP% %HEAP% %NEW% %SURVIVOR% %TENURING% %PERM% %DDRAW% %rmi_host%

6、确定在controller机器上安装jdk,版本和jmeter一致,配置环境变量:Java_home等
在Agent机器上安装jdk,配置环境变量:Java_home和JMeter_home
安装目录不要带空格,最好都是简短的英文路径

7、master机器启动后会拷贝jmx文件到slave机器,所以不需要在每台slave机器上也上传一份jmx,只需要在master机器上上传一份jmx脚本即可。

如果使用csv进行参数化,则需要把参数文件在每台slave上拷一份且路径需要设置成一样的。

总样本数 = 线程数 * 循环次数 * 执行机总数

8、连接失败原因排查
以下步骤进行排查:
1. jmeter-server是否启动;
2. 是否联网
3. ping 服务器IP是否畅通.
4. telnet 端口 192.168.3.10 1099
5. 检查服务器的防火墙是否关闭。
6. 阿里云安全策略是否正常

9、"could not find ApacheJmeter_core.jar"
解决:在Agent机器安装jdk,并设置环境变量

10、”Bad call to remote host"
解决:检查被控制机器上的jmeter-server有没有启动,或者remote_hosts的配置是否正确。

课程介绍:
亿级流量系列之Jmeter4.x分布式压测实战,2018年新录制采用Jmeter4.0版本,适合想往 中高级开发工程师或者测试工程师发展的人员,从零基础安装到使用
包含众多核心知识点,聚合报告分析,断言使用,自定义变量,读取CSV或txt多参数压测,JMX脚本讲解,阿里云Linux环境部署,
分布式压测,http接口,mysql数据库压测,html网页压测报告分析 等等;最终项目实战会在阿里云Linux服务器进行压测,真正的生产环境,采用多节点向应用服务器压测,并生成jtl和html可视化测试报告,还有新版本常见问题处理,架构设计等知识点。

授课计划
课程是2018年4月份新录制,采用jmeter4.x版本,分为28到30节课,会根据同学的需要适当进行补充,核心知识是在阿里云服务器上进行压测,掌握压测报告分析,和分布式压测的知识点

课程目标:
通过学习该课程,可以掌握jmeter核心知识点,并用于压测接口,可以在Linux服务器上面进行压测,且可以用Jmeter分布式压测模拟高并发情景去压测接口,并可以获取可视化html压测报告进行分析。

2018年 Jmeter4.0压测视频教程 独家录制
Jmeter4.0版本实战 阿里云Linux服务器压测实战
压测http,mysql,断言,自定义参数,聚合报告
CSV可变参数压测,分布式压测,JMX脚本讲解
html可视化测试报告讲解,测试瓶颈分析等

包含详细的学习笔记,专属技术交流群

csdn 2018年新版本亿级流量系列之Jmeter4.x分布式压测入门到实战

淘宝 2018年分布式Jmeter视频教程 入门到实战压力测试教程 jmeter4.0新版本

转载于:https://www.cnblogs.com/chuchu5811/p/11322480.html

Jmeter做接口的压力测试相关推荐

  1. 如何使用Jmeter对HTTP接口进行压力测试?

    我们不应该仅仅局限于某一种工具,性能测试能使用的工具非常多,选择适合的就是最好的.笔者已经使用Loadrunner进行多年的项目性能测试实战经验,也算略有小成,任何性能测试(如压力测试.负载测试.疲劳 ...

  2. jmeter可以做接口测试和压力测试(较全)

    jmeter是apache公司基于java开发的一款开源压力测试工具,体积小,功能全,使用方便,是一个比较轻量级的测试工具,使用起来非常简单.因为jmeter是java开发的,所以运行的时候必须先要安 ...

  3. 【总结】个人推荐的接口测试工具和接口性能/压力测试工具

    一般接口有2种测试,现在很多是模糊了这个,但是如果细分.一般还要写<接口测试用例>和<接口性能测试用例>.同样,也分接口测试报告和接口性能测试报告. 接口的本质及其工作原理 接 ...

  4. Jmeter教程 简单的压力测试

    Jmeter是一个非常好用的压力测试工具.  Jmeter用来做轻量级的压力测试,非常合适,只需要十几分钟,就能把压力测试需要的脚本写好. 阅读目录 什么是压力测试 做压力测试的常用工具 做压力测试的 ...

  5. NHibernate+WCF项目实战(四)使用WAS对Webservices接口进行压力测试

    NHibernate+WCF项目实战 第一篇.项目介绍与搭建: 第二篇.使用NHibernate实现数据访问并进行单元测试: 第三篇.使用WCF对外提供Webservices接口并进行单元测试: 第四 ...

  6. 工具使用-----Jmeter教程 简单的压力测试

    摘抄于http://www.cnblogs.com/TankXiao/p/4059378.html 以下是英文版的,中文版的也差不多的 Jmeter是一个非常好用的压力测试工具.  Jmeter用来做 ...

  7. 利用jmeter完成简单的压力测试

    Jmeter是一个非常好用的压力测试工具.Jmeter用来做轻量级的压力测试,非常合适,只需要十几分钟,就能把压力测试需要的脚本写好. 1.什么是压力测试 顾名思义:压力测试,就是 被测试的系统,在一 ...

  8. MAC结合LINUX进行Jmeter进行java代码压力测试

    一.环境准备 下载jdk包 地址:https://www.oracle.com/java/technologies/downloads/#java8 centos 下载 x64 Compressed ...

  9. 使用JMeter进行MySQL的压力测试

    前言 1. JMeter安装 2. 导入MySQL驱动 3. 配置并使用JMeter连接数据库 step1:添加JDBC Connection Configuration step2:添加JDBC R ...

最新文章

  1. 力扣(LeetCode)933
  2. linux下将硬件时钟调整为与本地时钟一致
  3. Flash 图片轮换效果
  4. Lintcode18 Subsets II solution 题解
  5. 7 个习惯帮你提升Python运行性能
  6. [高斯消元及理论]线性方程组整数/浮点数,模线性方程组,异或方程组模板
  7. 做项目时的几个感慨(持续更新...)
  8. 20个使用柔和的色调的优秀网站设计示例
  9. 《WINDOWS游戏编程之从零开始》第三章学习笔记
  10. 国风PPT自制卷轴动效,你的PPT也能很“香“
  11. 【Keil变量定义】定义extern类型变量
  12. Block-scoped declarations (let, const, function, class) not yet supported outs报错解决
  13. AR智能眼镜tooz DevKit 20初体验
  14. SpringCloud平滑升级/优雅停机
  15. Delphi UAC生成默认以管理员身份运行的可执行程序
  16. Unity PSD导入到Unity
  17. win10+1060+tensorflow-gpu安装过程
  18. scaner从外网到内网域渗透笔记
  19. PHP生成带图片的Excel
  20. UI设计必备工具有哪些?

热门文章

  1. 有人把微信“跳一跳”玩到10000分,高分秘籍是…
  2. C++标准模板库之map及pair
  3. python协程和线程_线程和协程之间的区别
  4. 程序员过中秋的一百种方式
  5. php 读取excel大文件,php 如何读大excel
  6. hbase 协处理器 部署_HBase协处理器加载的三种方式
  7. Mac软件如何安装与卸载
  8. 展会邀请 | 虹科诚邀您4月26-28日前来参观成都国际工业博览会
  9. jQuery实现表格的增加、修改、删除、保存。
  10. 【测开】在线音乐服务器测试报告