在Linux使用Jmeter做性能测试需要4个前提条件,这4个前提条件已经在之前的文档里提到了,重复一下加深印象:

(1) 在本地已安装xshell    参考《SecureCRT-转换密钥-Xshell-配置服务-使用xshell登录远程linux服务器

(2) 在Linux有Java运行环境    参考《Jmeter-安装JDK- 配置Jmeter运行的环境 - 是使用Jmeter的前提

(3) 在Linux已安装Jmeter    参考《Jmeter-安装Jmeter - 在Linux环境安装Jmeter - 在Windows环境安装Jmeter

(4) 在Linux已配置HOSTS    参考《在Linux配置HOSTS的方法》、《在Windows配置HOSTS的方法

那么本篇文档里会介绍:

(5) 在Windows构建1个测试脚本                        //第1个步骤

(6) 在Windows,参数化这个测试脚本                      //第2个步骤

(7) 在Windows把构建的这个测试脚本转化为用在Linux的测试脚本:        //第3个步骤

  a) 修改“线程组”的“线程数”、“启动线程时间”、“循环次数”、“调度器”

  b) 参数化Request的值

  c) 参数化Request的路径

  d) 将“测试结果树”修改为“聚合报告”

  e) 配置“聚合报告”的文件名

  f) 配置“聚合报告”的Configure

第1个步骤:在Windows构建1个测试脚本 ( 以访问豆瓣的电影为例 )

场景1:验证用户访问豆瓣网站里《博物馆奇妙夜》这部电影(http://movie.douban.com/subject/1835843/)的页面。

#如何在Windows构建1个测试脚本可以参考之前的文档《Jmeter-一个完整的接口测试的脚本》,那篇文档描述得更加详细。所以本篇文档只作截图。但是也能很明白。

测试计划节点

因为我们是在Windows构建这个测试脚本,建议为这个脚本加1个标识(如:testPlanForWindows)[说白了,就是把测试计划保存的时候,名字写成"testPlanForWindows.jmx"]。这样就不会与"第3个步骤的测试脚本"混淆。

线程组节点

系统默认的“线程数”、“启动线程时间”、“循环次数”都是1,暂不作修改

HTTP请求默认值节点

HTTP请求节点

《博物馆奇妙夜》这部电影的URL是:http://movie.douban.com/subject/1835843/

察看结果树节点

运行一下测试脚本,看看脚本是不是能用

看看取样器结果返回是否:200 ok

看看Request这个URL是否写对了

通常我们在“HTTP请求默认值”写域名或者IP,在“HTTP请求”写剩余的URL,Jmeter会将这两部分的URL自动拼接成1个完整的Request URL。那么如果某1部分写错了,那么就会HTTP404,此时切换到“察看结果树-请求TAB”检查检查Request URL具体是哪里写错了,然后到“HTTP请求默认值”和“HTTP请求”修改正确就可以了。

第2个步骤:在Windows参数化这个测试脚本 ( 以访问豆瓣的电影为例,既然是参数化,那么就不只是访问1部电影了,我们以访问2部电影举例 )

场景1:验证用户访问豆瓣网站里《博物馆奇妙夜》这部电影的页面。

场景2:验证用户访问豆瓣网站里《博物馆奇妙夜》、《憨豆特工》这2部电影的页面。

那么先把两部电影的URL摆出来:

《博物馆奇妙夜》 http://movie.douban.com/subject/1835843/

《憨豆特工》http://movie.douban.com/subject/1307389/

我们只需要把“HTTP请求节点”处理一下就可以了

HTTP请求节点

1、 对比一下参数化前后这个URL的变化

参数化前:/subject/1835843/

参数化后:/subject/${__CSVRead(E:\movies.csv,0)}${__CSVRead(E:\movies.csv,next)}/

2、 说明一下这2个URL的意思

参数化前:查看某1个豆瓣电影

参数化后:查看很多个豆瓣电影

3、 了解一下E:\movies.csv文件是什么?里面有什么?

E:\movies.csv文件是什么:.csv文件是Jmeter参数化的文件,当并发请求时,Jmeter会读取这个文件。

E:\movies.csv文件里面有什么:每1行是1个电影ID,如下图所示

4、 说明一下怎么制作这个.csv文件

  a) 新建1个写字板文件

  b) 第1行写1条数据

  c) 第2行写1条数据

  d) 保存

  e) 将.txt后缀修改为.csv

  [ 备注:当.csv文件需要有上百条数据,需要使用脚本语言自己写,或者由开发人员协助生成这个.csv格式的文件 ]

5、 重点说明一下错误的"制作.csv文件的方式

  a) 新建1个Excel文件

  b) 第1行写1条数据,第2行写1条数据,保存

  c) 将.xls后缀修改为.csv

  因为Excel会涉及文本的样式、编码等东西,所以当最终将.xls保存为.csv后,在运行Jmeter的时候,参数化的东西读取存在乱码,那么就会造成HTTP404。

6、 说明一下CSVRead函数的意思

参数化后:/subject/${__CSVRead(E:\movies.csv,0)}${__CSVRead(E:\movies.csv,next)}/

意思是:Jmeter从E:\movies里面的第0行开始读数据,读完第0行接着读下一行。

7、 看看Request这个参数化了的URL是否写对了

//因为有2个电影ID嘛,所以我们可以将“线程组-线程数”设置是2

第3个步骤:在Windows把构建的这个测试脚本转化为用在Linux的测试脚本

1. 建议新建1个一模一样的测试脚本

这么做的目的是:减轻工作量,事半功倍。

2. 命名方式

testPlanForWindows.jmx       //第1个步骤、第2个步骤均使用了这个测试脚本,使用的是同一个测试脚本

testPlanForLinux.jmx        //第3个步骤需要新建1个测试脚本,命名为"testPlanForLinux.jmx"

3.testPlanForLinux.jmx有哪些不一样的地方

a) 线程组

//注意:我们当前执行的修改,都是在1个新的测试脚本内操作的,即:testPlanForLinux.jmx

b) HTTP请求

我们去掉了E:\,因为在Linux是没有E:\这个路径的。

由于我们会将moives.csv上传到远程Linux服务器的“Jmeter安装文件”的bin目录下(即:与Jmeter可执行文件是同一级目录),那么所以我们直接去掉E:\就可以了。

c) 聚合报告

"文件名":../../result/testResult.csv

"Configure":保留如下5项

Save Filed Names(CSV):结果文件以CSV的形式保存

Save Response Code:保存返回值,比如http的200、4xx、5xx    //如果是4xx,首先去检查hosts文件是否配置ok了。如果是5xx,去找开发问问是不是在nginx里deny了测试机的请求,是的话把测试机ip加到服务器的配置文件里。

Save Time Stamp:每一条服务器的响应显然对应了一个本地的时间,比如现在是2014年4月24号11:17,那么在这条响应的旁边显示了201404241117

Save Latency:保存请求被服务器响应的时间,比如20毫秒、50毫秒、100毫秒

Save URL:保存测试机向服务器发送的请求,完整记录下来,有利于检查拼接的URL是不是正确的,有没有失误导致URL多了一个空格或者少了什么

至此,接下来就可以将testPlanForLinux.jmx和movies.csv上传到远程Linux测试机了,上传的目录是Jmeter安装文件的bin目录下。然后就可以在Linux使用Jmeter做性能测试了。(具体操作我仍然会输出1个文档)

【NO.11】Jmeter - 构建1个可供Linux使用的Jmeter测试脚本 - 共3个步骤的更多相关文章

  1. jmeter(二十五)linux环境运行jmeter并生成报告

    jmeter是一个java开发的利用多线程原理来模拟并发进行性能测试的工具,一般来说,GUI模式只用于创建脚本以及用来debug,执行测试时建议使用非GUI模式运行. 这篇博客,介绍下在linux环境 ...

  2. 【NO.13】Jmeter - 在Linux整理和计算测试结果

    我们现在描述的是:在Linux系统使用Jmeter执行性能测试. 所以当执行完测试以后,就要计算一下测试结果,反馈给开发人员嘛. 在Linux系统使用Jmeter执行性能测试都包含哪些步骤,来,回顾一 ...

  3. Linux下搭建Jmeter+Ant+Jenkins自动化测试框架

    前言 在之前的文章中,我们学习了通过Ant调用Jmeter脚本生成HTML测试报告,但未实现自动执行脚本生成报告,同时生成的报告是在Linux下,查看报告很不方便.因此,我们将结合Jenkins来进一 ...

  4. AWS EC2+Docker+JMeter构建分布式负载测试基础架构

    目录 概述及范围 前提条件 Part 1: Local setup-本地配置 Part 2: Cloud端基础架构--Infrastructure 总结: 原文链接 @ 概述及范围 本文介绍有关如何使 ...

  5. 高性能Linux服务器 第11章 构建高可用的LVS负载均衡集群

    高性能Linux服务器 第11章 构建高可用的LVS负载均衡集群 libnet软件包<-依赖-heartbeat(包含ldirectord插件(需要perl-MailTools的rpm包)) l ...

  6. jmeter 构建一个Web测试计划

    添加用户 第一步你想做的每一个JMeter测试计划是添加一个 线程组 元素. 线程组告诉 JMeter的用户数量你想模拟,用户应该发送的次数 请求,请求他们应该送多少. 继续添加ThreadGroup ...

  7. jeakins+maven+jmeter构建性能测试自动化( 在eclipse里运行如果出现没有找到“*.loadtest.xls”,请将此文件名修改为你对应使用的xsl文件名)

    背景: 首先用jmeter录制或者书写性能测试的脚本,用maven添加相关依赖,把性能测试的代码提交到github,在jenkins配置git下载性能测试的代码,配置运行脚本和测试报告,配置运行失败自 ...

  8. 【NO.2】Jmeter-安装Jmeter - 在Linux环境安装Jmeter - 在Windows环境安装Jmeter

    当配置完Jmeter运行的环境之后,就可以开始安装Jmeter了. 为什么既要告诉各位"在Linux系统内安装Jmeter",又要告诉各位"在Windows系统内安装Jmeter"?因为当我们在构建1 ...

  9. Jenkins+Jmeter持续集成笔记(二:ANT执行Jmeter脚本)

    Jmeter接口测试脚本运行后生成的是jtl(xml)格式的文件,这些文件不具备可读性,所以我们要把他转化为可以阅读的html格式报告. Ant是一个功能强大的打包编译工具.我们使用他的目的是将xml ...

随机推荐

  1. python迭代器生成器(二)

    其他内置类型迭代器 除了文件以及列表这样的实际的序列外,其他类型也有适合的迭代器. 遍历字典的经典方法是明确的获取其键的列表. 在最近的python版本中,字典有一个迭代器,在迭代环境中,会自动一次返 ...

  2. python yield from 语法

    python yield from 语法 yield语法比较简单, 教程也很多 , yield from的中文讲解很少 , python官网是这样解释的 PEP 380 adds the yield ...

  3. WebAssembly:随风潜入夜

    What? WebAssembly 是一种二进制格式的类汇编代码,可以被浏览器加载和并进一步编译成可执行的机器码,从而在客户端运行.它还可以作为高级语言的编译目标,理论上任何语言都可以编译为 WebA ...

  4. jquery.jqprint-0.3.js打印table表格遇到的坑

    在谷歌控制台输入window.print();可以调起当前整个页面的打印预览,那么要想打印页面某块区域内容怎么办呢? 我找到了jqprint插件,其原理是运用iframe 元素创建另外一个文档的内联框 ...

  5. MapReduce执行流程及程序编写

    MapReduce 一种分布式计算模型,解决海量数据的计算问题,MapReduce将计算过程抽象成两个函数 Map(映射):对一些独立元素(拆分后的小块)组成的列表的每一个元素进行指定的操作,可以高度 ...

  6. 如何查看安装的sql server是什么版本

    方法 1:通过使用 SQL Server Management Studio 中的对象资源管理器连接到服务器.连接对象资源管理器后,它将显示版本信息(在括号中),以及用于连接到 SQL Server ...

  7. 面向对象15.3String类-常见功能-获取-2

    public class String_APImethod {/* * 1.4获取字符串中的一部分字符串,也叫字符串 * String substring(int beginIndex, int en ...

  8. Python 批量翻译 使用有道api;

    妹子是做翻译相关的,遇到个问题,要求得到句子中的所有单词的 音标; 有道翻译只能对单个单词翻译音标,不能对多个单词或者句子段落翻译音标; 手工一个一个翻的话那就要累死人了.....于是就让我写个翻译音 ...

  9. Java IO 之 BIO、NIO、AIO

    1.BIO.NIO.AIO解释 Java BIO : 同步并阻塞 (Blocking IO) 一个连接一个线程 即客户端有连接请求时服务器端就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不 ...

  10. 扩展entity framework core 实现默认字符串长度,decimal精度,entity自动注册和配置

    报道越短,事情越严重!文章越短,内容越精悍! 文章以efcore 2.0.0-preview2.测试验证通过.其他版本不保证使用,但是思路不会差太远.源代码 目标: 1.实现entity的自动发现和m ...