精华内容
下载资源
问答
  • JMeter并发测试

    2020-11-06 17:53:07
    前言 新作的小视频大赛即将上线,参加的院校目前有43个… ...Apache JMeter是一款纯java编写负载功能测试和性能测试开源工具软件。相比Loadrunner而言,JMeter小巧轻便且免费,逐渐成为了主流的性能

    前言

    新作的小视频大赛即将上线,参加的院校目前有43个…
    小团队没有测试,极为担心,索性自己搞了搞。。
    自己随便玩了玩…
    300个线程,每个线程连续请求5次,部分请求会返回http500,redis拒绝连接
    100个线程,每个线程连续请求5次,全部正常返回200
    在这里插入图片描述

    以下是转载内容:

    1. Jmeter简介

    Apache JMeter是一款纯java编写负载功能测试和性能测试开源工具软件。相比Loadrunner而言,JMeter小巧轻便且免费,逐渐成为了主流的性能测试工具,是每个测试人员都必须要掌握的工具之一。

    本文为JMeter性能测试完整入门篇,从Jmeter下载安装到编写一个完整性能测试脚本、最终执行性能测试并分析性能测试结果。

    运行环境为Windows 10系统,JDK版本为1.8,JMeter版本为3.3。

    2. Jmeter安装

    2.1 JDK安装

    由于Jmeter是基于java开发,首先需要下载安装JDK (目前JMeter只支持到Java 8,尚不支持 Java 9)
    1. 官网下载地址:http://www.oracle.com/technetwork/java/javase/downloads/index.html
    2. 选择Java SE 8u151/ 8u152,点击JDK下载
    这里写图片描述
    3. 安装下载的JDK
    4. 配置系统环境变量

    2.2 JMeter安装

    1. 官网下载地址:http://jmeter.apache.org/download_jmeter.cgi
    2. 下载最新JMeter 3.3版本:apache-jmeter-3.3.zip
      这里写图片描述
    3. 下载完成后解压zip包
    4. 启动JMeter
      双击JMeter解压路径(apache-jmeter-3.3\bin)bin下面的jmeter.bat即可
      这里写图片描述

    3. 测试实例

    我们选取最常见的百度搜索接口:

    3.1 接口地址

    http://www.baidu.com/s?ie=utf-8&wd=jmeter性能测试

    3.2 请求参数

    ie:编码方式,默认为utf-8
    wd: 搜索词

    3.3 返回结果

    搜索结果,我们可以通过校验结果中是否含有搜索词wd来判断本次请求成功或失败。

    4. JMeter脚本编写

    4.1 添加线程组

    右键点击“测试计划” -> “添加” -> “Threads(Users)” -> “线程组”
    这里写图片描述
    这里可以配置线程组名称,线程数,准备时长(Ramp-Up Period(in seconds))循环次数,调度器等参数:
    这里写图片描述
    线程组参数详解:
    1. 线程数:虚拟用户数。一个虚拟用户占用一个进程或线程。设置多少虚拟用户数在这里也就是设置多少个线程数。
    2. Ramp-Up Period(in seconds)准备时长:设置的虚拟用户数需要多长时间全部启动。如果线程数为10,准备时长为2,那么需要2秒钟启动10个线程,也就是每秒钟启动5个线程。
    3. 循环次数:每个线程发送请求的次数。如果线程数为10,循环次数为100,那么每个线程发送100次请求。总请求数为10*100=1000 。如果勾选了“永远”,那么所有线程会一直发送请求,一到选择停止运行脚本。
    4. Delay Thread creation until needed:直到需要时延迟线程的创建。
    5. 调度器:设置线程组启动的开始时间和结束时间(配置调度器时,需要勾选循环次数为永远)
    持续时间(秒):测试持续时间,会覆盖结束时间
    启动延迟(秒):测试延迟启动时间,会覆盖启动时间
    启动时间:测试启动时间,启动延迟会覆盖它。当启动时间已过,手动只需测试时当前时间也会覆盖它。
    结束时间:测试结束时间,持续时间会覆盖它。

    因为接口调试需要,我们暂时均使用默认设置,待后面真正执行性能测试时再回来配置。

    4.2 添加HTTP请求

    右键点击“线程组” -> “添加” -> “Sampler” -> “HTTP请求”
    这里写图片描述
    对于我们的接口http://www.baidu.com/s?ie=utf-8&wd=jmeter性能测试,可以参考下图填写:
    这里写图片描述
    Http请求主要参数详解:

    1. Web服务器
      协议:向目标服务器发送HTTP请求协议,可以是HTTP或HTTPS,默认为HTTP
      服务器名称或IP :HTTP请求发送的目标服务器名称或IP
      端口号:目标服务器的端口号,默认值为80
      2.Http请求
      方法:发送HTTP请求的方法,可用方法包括GET、POST、HEAD、PUT、OPTIONS、TRACE、DELETE等。
      路径:目标URL路径(URL中去掉服务器地址、端口及参数后剩余部分)
      Content encoding :编码方式,默认为ISO-8859-1编码,这里配置为utf-8
    2. 同请求一起发送参数
      在请求中发送的URL参数,用户可以将URL中所有参数设置在本表中,表中每行为一个参数(对应URL中的 name=value),注意参数传入中文时需要勾选“编码”

    4.3 添加察看结果树

    右键点击“线程组” -> “添加” -> “监听器” -> “察看结果树”
    这里写图片描述
    这时,我们运行Http请求,修改响应数据格式为“HTML Source Formatted”,可以看到本次搜索返回结果页面标题为”jmeter性能测试_百度搜索“。
    这里写图片描述

    4.4 添加用户自定义变量

    我们可以添加用户自定义变量用以Http请求参数化,右键点击“线程组” -> “添加” -> “配置元件” -> “用户定义的变量”:
    这里写图片描述
    新增一个参数wd,存放搜索词:
    这里写图片描述
    并在Http请求中使用该参数,格式为:${wd}
    这里写图片描述

    4.5 添加断言

    右键点击“HTTP请求” -> “添加”-> “断言” -> “响应断言”
    这里写图片描述
    我们校验返回的文本中是否包含搜索词,添加参数${wd}到要测试的模式中:
    这里写图片描述

    4.6 添加断言结果

    右键点击“HTTP请求” -> “添加”-> “监听器” -> “断言结果”
    这里写图片描述

    这时,我们再运行一次就可以看到断言结果成功或失败了
    这里写图片描述

    4.7 添加聚合报告

    右键点击“线程组” -> “添加” -> “监听器” -> “聚合报告”,用以存放性能测试报告
    这里写图片描述
    这样,我们就完成了一个完整Http接口的JMeter性能测试脚本编写。

    5. 执行性能测试

    5.1 配置线程组

    点击线程组,配置本次性能测试相关参数:线程数,循环次数,持续时间等,这里我们配置并发用户数为10,持续时间为60s
    这里写图片描述

    5.2 执行测试

    点击绿色小箭头按钮即可启动测试,测试之前需要点击小扫把按钮清除之前的调试结果。
    这里写图片描述

    6. 分析测试报告

    待性能测试执行完成后,打开聚合报告可以看到:
    这里写图片描述

    聚合报告参数详解:
    1. Label:每个 JMeter 的 element(例如 HTTP Request)都有一个 Name 属性,这里显示的就是 Name 属性的值
    2. #Samples:请求数——表示这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100
    3. Average:平均响应时间——默认情况下是单个 Request 的平均响应时间,当使用了 Transaction Controller 时,以Transaction 为单位显示平均响应时间
    4. Median:中位数,也就是 50% 用户的响应时间
    5. 90% Line:90% 用户的响应时间
    6. Min:最小响应时间
    7. Max:最大响应时间
    8. Error%:错误率——错误请求数/请求总数
    9. Throughput:吞吐量——默认情况下表示每秒完成的请求数(Request per Second),当使用了 Transaction Controller 时,也可以表示类似 LoadRunner 的 Transaction per Second 数
    10. KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec

    一般而言,性能测试中我们需要重点关注的数据有: #Samples 请求数,Average 平均响应时间,Min 最小响应时间,Max 最大响应时间,Error% 错误率及Throughput 吞吐量。

    7. 源码下载

    至此,我们使用JMeter完成了一个完整的Http接口性能测试流程,从脚本编写,执行到最终结果分析。

    完整的脚本源码下载链接: https://pan.baidu.com/s/1eS90cVo 密码: st15

    展开全文
  • jmeter并发测试

    2018-08-16 13:40:00
    简单来理解一下,虽然我们的“性能测试”理解为“多用户并发测试”,但真正的并发是不存在的,为了更真实的实现并发这感念,我们可以在需要压力的地方设置集合点,每到输入用户名和密码登录时,所有的虚拟用户都相互...

    用jmeter测试高并发,老大要求是在0秒内1000个用户同时登录

    想到了2种方法

    1.在线程组里直接设置

    2.设置集合点

    简单来理解一下,虽然我们的“性能测试”理解为“多用户并发测试”,但真正的并发是不存在的,为了更真实的实现并发这感念,我们可以在需要压力的地方设置集合点,每到输入用户名和密码登录时,所有的虚拟用户都相互之间等一等,然后,一起访问。

    注意:

    1.JMeter里面的集合点通过添加定时器来完成。

    2.Synchronizing timer仅作用于同一个JVM中的线程。

    集合点的用法:

     

    Number of Simulated Users to Group by:集合多少人后再执行请求(也就是执行的线程数)

    注意:等同于设置为线程租中的线程数,一定要确保设置的值不大于它所在线程组包含的用户数。

    Timeout in milliseconds:指定人数 多少秒没集合到算超时(设置延迟时间以毫秒为单位)

    注意:如果设置Timeout in milliseconds为0,表示无超时时间,会一直等下去。
    线程数量无法达到"Number of Simultaneous Users to Group by"中设置的值,那么Test将无限等待,除非手动终止。

    如果希望定时器仅应用于其中一个sampler,则把该定时器作为子节点加入,如下图

    关于集合点的概念大神写过(https://blog.csdn.net/zjq001x/article/details/53107159

     

    关于这两点的区别以及好坏,研究了一下午总结了以下几点

    并发:其实是一个理想状态下的概念而已,一般是指在一段时间内到达的访问量

    集合点:是将到达集合点函数的线程Hold住,等到符合集合点数量时再释放,但是,你的CPU是有限的,所以不可能真正做到同时释放,另外线程间切换也需要时间

    总的来说:使用集合点,能大致达到真实并发情况,使用线程组也可以将等待时间设置0,只不过对测试机器性能消耗较大。(个人理解,仅供参考)

     注意:线程等待时间为0的条件下,随机性更大一些,不像设置集合点那样规律明显

     

     

    每天进步一点点,一点点

    转载于:https://www.cnblogs.com/yang2017812/p/9486793.html

    展开全文
  • Jmeter并发测试

    2020-09-30 10:54:50
    在一段高速公路上,安装有3台智慧灯杆,当有车辆经过时,会通过灯杆上安装好的雷达、摄像头等将车辆信息(包括车牌号、车速、位置等信息)上传至后台管理平台进行显示,现需测试后台系统性能。 二.Test Plan 1....

    一.背景

    在一段高速公路上,安装有3台智慧灯杆,当有车辆经过时,会通过灯杆上安装好的雷达、摄像头等将车辆信息(包括车牌号、车速、位置等信息)上传至后台管理平台进行显示,现需测试后台系统性能。

    二.Test Plan

    1.jmeter中添加线程组,设置线程数100个,循环100次,此后每次添加10个线程进行压测。

    2.添加http请求,请求方式为post,发送数据为json数据

    其中参数需做如下设置:

    (1).由于上传的信息需带实时时间,因此需将接口里面的"dateTime"进行参数化,设置为获取当前时间: "${__time(yyyy-MM-dd HH:mm:ss,)}"

    (2).使用随机函数模拟多个车牌号plateNo: "鄂R1234${__Random(0,19,random_num_0_19)}"

    (3).使用随机函数模拟车辆行驶的车道"laneNo": ${__Random(1,4,random_num_1_4)}

    (4).经纬度信息使用参数化设置,如下:

    首先添加配置单元:

    设置需要进行参数化的字段,以及将准备数据

    在请求数据里引用参数化:

    3.添加http header manager

    设置content-type为application/json

    4.添加响应断言

    设置返回成功的信息,若不是返回设置好的信息,则会判定为请求失败。

    5.添加查看结果树和聚合报告

     

    至此,设置完成,运行脚本查看结果。

     

     

    展开全文
  • jmeter并发测试报错

    2021-01-14 15:26:23
    jmeter并发测试报错 请大神给指点一下是因为什么报错,并发循环1-5次的时候不会报错,循环多次就开始报错了。

    jmeter并发测试报错

    请大神给指点一下是因为什么报错,并发循环1-5次的时候不会报错,循环多次就开始报错了。
    在这里插入图片描述

    展开全文
  • Jmeter并发测试接口

    2021-01-07 17:54:47
    Jmeter并发测试接口 固定参数 场景:每次请求接口时使用同样的参数。 新建计划: File→ New 。 在Name中可以输入计划名称 2. 新建线程组:在刚刚新建的计划上右键→ add→ Threads(Users)→ Thread...
  • jmeter是Apache组织开发的基于Java的压力测试工具,用于对软件做压力测试,很多用户使用的时候不知道jmeter怎么进行并发测试,接下来就跟小编一起来看看吧,有需要的小伙伴不要错过!jmeter怎么进行并发测试1、打开...
  • JMeter并发测试Jmeter是一个非常好用的压力测试工具。Jmeter用来做轻量级的压力测试,非常合适,只需要十几分钟,就能把压力测试需要的脚本写好。目录1.什么是压力测试2.做压力测试的常用工具3.做压力测试的步骤如下...
  • jmeter是Apache组织开发的基于Java的压力测试工具,用于对软件做压力测试,很多用户使用的时候不知道jmeter怎么进行并发测试,接下来就跟小编一起来看看吧,有需要的小伙伴不要错过!jmeter怎么进行并发测试1、打开...
  • jmeter是apache公司基于java开发的一款开源压力测试工具,体积小,功能全,使用方便,是一个比较轻量级的测试工具,使用起来非常简单。因为jmeter是java开发的,所以运行的时候必须先要安装jdk才可以。jmeter是...
  • Jmeter并发测试工具

    2019-03-26 14:02:34
    JMeter主要是用来进行负载和性能测试。...JMeter通常被用来对一些静态的或者动态...简单的说:是Apache下的一个测试工具,可以对服务器进行并发测试,测试服务器所能承受的并发量,以各种曲线图或者数据表展示出测试数据。
  • 采样器,监听器,配置JMeter性能测试工具快速入门教程4测试计划和工作台JMeter性能测试工具快速入门教程5性能和负载测试JMeter性能测试工具快速入门教程6定时器JMeter性能测试工...
  • 接口测试测试工程师的必备技能之一,运用JMeter工具一步步实现接口请求,数据参数化,断言等操作,通过常见的企业实际测试场景详解JMeter各项技术使用,最后结合Jenkins持续集成实现企业级小程序接口自动化测试,...
  • JMeter/jmeter 并发测试 多进程测试

    万次阅读 2018-08-23 17:32:23
    *多线程测试 指的是在短时间内多次重复请求 *多进程测试 指的是同一时间内多次重复请求 下面图文展示操作步骤: 一、添加线程组 先新建一个测试计划 如下图: 创建线程组: 在新建的测试计划上右键 如下图:...
  • 1、Jmeter分布式测试时,选择其中一台作为调度机(master客户端),其它机器做为执行机(slave服务端)。2、执行时,master会把脚本发送到每台slave上,slave拿到脚本后就开始执行,slave执行时不需要启动GUI,我理解它...
  • JMeter压力测试集合点教程基本公式线程数=QPS*time注:QPS--每秒完成请求的个数;time--每个请求响应完成平均需要时间故QPS*time就是所有请求完成响应所需要的总时间,如果需要在一秒完成所有请求的响应,所以线程数...
  • Jmeter多用户并发压力测试过程图解jmeter多用户并发压力测试可用CSV Data Set Config (添加--配置元件--CSV Data Set Config)Filename: 文件的位置(如果是同目录下csv文件,可不填写路径,写名称即可)Variable Names...
  • JMeter并发测试工具

    2019-07-13 11:30:10
    这里介绍JMEter的简单并发测试 下载安装完成后打开bin\jmeter.bat, 必须先安装java环境, 打开软件后找到Options>choose Langguage>Chinese,先把软件的语言改为中文,英文好的可以忽略 创建一个监听器...
  • 最新书籍,可以直接下载测试开发实战:Pro Apache JMeter Web Application Performance​zhuanlan.zhihu.com测试开发实战:Performance Testing with JMeter 3 - Third Edition​zhuanlan.zhihu.comJMeter快速入门...
  • jmeter并发测试简介

    2020-08-24 11:13:06
    jmeter性能测试笔记 目的:不同用户同一时间对一个接口进行访问的成功率 1.http请求信息 将传入的参数用${content}参数化读取 2.请求头信息 将头部信息msisdn参数化处理 3.参数化数据 用数据元件CSV Data Set ...
  • jmeter并发测试工具

    2020-10-04 20:49:51
    单击文件,新建一个测试计划 在该测试计划下新建线程组,在线程组下新建HTTP请求,CSV数据文件设置以及 察看结果树 点击线程组,设置线程数。 点击Http请求,设置协议(http),服务器IP(127.0.0.1),端口,以及http请求...
  • postman的runner是串行的,上一个请求结束后才开始下一个请求,属于连续测试不属于并发测试JMeter可以指定用户数,发请求的间隔时间,可以模拟并发测试
  • jmeter并发测试实例

    2020-07-10 15:44:09
  • Linux jmeter并发测试

    2020-04-09 23:24:33
    问题记录:Uncaught Exception java.lang.OutOfMemoryError 解决办法:
  • 1、 2、 3、注:实际图表和上述设置的并发量不一致 4、注:实际图表和上述设置的并发量不一致
  • 1. Jmeter简介Apache JMeter是Apache组织开发的基于Java的压力测试工具。用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域。JMeter 可以用于对服务器、网络或对象模拟巨大的负载,来自...
  • Jmeter并发测试(抽奖系统)

    千次阅读 2017-12-19 15:40:55
    Jmeter 是一款使用Java开发的,开源免费的,测试工具, 主要用来做功能测试和性能测试(压力测试/负载测试). 而且用Jmeter测试 Restful API, 非常好用。
  • 使用git bash 运行命令ulimit -a可以看到open files等于256,也就是我运行JMeter的机器,最大文件句柄数是256。 $ ulimit -a core file size (blocks, -c) unlimited data seg size (kbytes, -d) unlimited file ...
  • Jmeter并发测试redis分布式锁

    千次阅读 2018-09-09 20:21:30
    项目使用springboot,定义成员变量private int num = 20,测试对公共资源的抢占,只有20个号码,26个字母去抢,并发的去请求接口操作num,请求时,如果num大于0,给该请求分配号码,即抢占成功,否则失败。...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 3,383
精华内容 1,353
关键字:

jmeter并发测试