zoukankan      html  css  js  c++  java
  • JMeter 分布式测试部署

    对于并发量很大的需求,如上万并发量,受到CPU和内存的限制,单机模拟场景是实现不了的,为了让JMeter提供更大的负载能力,须使用它的分布式机制,即多台机器同时产生负载的功能。

    以下参数分析可用于配置负载分布台数的参考:通常,4G内存最多可达到2000左右的并发量。在1.4G Hz~3GHz 的CPU 、1GB 内存的 JMeter 客户端上,可以处理线程 100~300。但是Web Service 例外。XML处理是 CPU 运算密集的,会迅速消耗掉所有的CPU 。一般来说,以XML技术为核心的应用系统,其性能将是普通Web 应用的 10%~25% 。另外,如果所有负载由一台机器产生,网卡和交换机端口都可能产生瓶颈,所以一个JMeter 客户端线程数不应超过 100 。其实我们可以根据这个大概的情况自己调试一下,比如单机上放一个数量级的并发量 500、1000跑起来看看CPU的使用情况,最佳状态是CPU占有率不超过80%。

    Jmeter分布式执行原理:

      1、Jmeter分布式测试时,选择其中一台作为调度机(master),其它机器做为执行机(slave or Agent)。

      2、脚本在master的GUI打开,测试计划仅在master上部署即可,执行时,master GUI会把测试计划发送到每台slave上,slave 拿到脚本后就开始执行,slave执行时不需要启动自己的GUI。每一台jmeter远程服务器都执行相同的测试计划,jmeter不会在执行期间做负载均衡,每一台服务器都会完整地运行测试计划。

      3、执行完成后,slave会把结果回传给master,master会收集所有slave的信息并汇总。

    分布式集群的配置

      在部署前请保证各slave机的防火墙处于关闭状态,master与各台slave都可以ping通。

    一、执行机(slave)配置:

      1、slave机上需要安装Jmeter 和 支持当前Jmeter版本的JDK。(有时在运行Jmeter时会提示JDK版本过低)

      2、添加环境变量:JMETER_HOME路径为bin目录的上一级目录,这样启动jmeter-server服务时,就只会看到Found ApacheJMeter_core.jar

      3、启动bin目录下的:jmeter-server.bat,启动成功如下图。(jmeter 的安装路径不要包含空格,因为jmeter-server.bat不支持含空格的文件夹路径。)

      4、上图上标红的IP和端口会在master里配置时用到。IP就是slave机器IP,端口默认是1099,端口也可以自定义,这里我自定义为1000。 

      5、多台slave的话,重复1~4步骤就好。

    二、调度机(master)配置:

      1、把待测脚本导入JMeter,为了调试方便,可以为脚本添加“查看结果树”。

      2、找到Jmeter的bin目录下的配置文件jmeter.properties,修改如下配置:

            remote_hosts=10.13.223.202:1000,10.13.225.12:1000       多台slave之前用 "," 隔开。

      3、打开Jmeter,选择“运行”菜单,可以依次点击远程启动中的slave来执行脚本,对应的slave命令行窗口上会看到启动的信息,全部启动的话可以选择远程全部启动。

       远程停止同理,也可以远程退出。

      

      每一台jmeter远程服务器都执行相同的测试计划,就是在master上设定好的测试计划

      slave向master回传信息时如果请求执行成功了则不回传具体每个请求的Response信息,当你用查看结果树查看结果时,只能看到取样结果是200,而响应数据里面是空的。

      

      

    自定义端口:

      如何自定义slave端口?

      1、在slave机的Jmeter的bin目录下,找到jmeter.properties文件,修改如下两个配置项,比如我这里修改为1888:

          server_port=1888

          server.rmi.localport=1888

      2、启动slave机上的jmeter-server.bat,如下图,端口已经修改为:1888

      

      3、修改master机器的jmeter.properties文件:

          remote_hosts=10.13.223.202:1000,10.13.225.12:1888

      4、重启jmeter.bat,如下图,端口已经变了:

      

    其它说明:

      1、调度机(master)和执行机(slave)最好分开,由于master需要发送信息给slave并且会接收slave回传回来的测试数据,所以mater自身会有消耗,所以建议单独用一台机器作为mater。

      2、参数文件:如果使用csv进行参数化,那么需要把参数文件在每台slave上拷一份且路径需要设置成一样的,Filename这里设定一下。

      

      3、每台机器上安装的Jmeter版本和插件最好都一致,否则会出一些意外的问题。

      4、如果想要master也分担负载,让master自身也执行测试计划,需要把master 的 IP 和 端口也写到配置文件里,在远程启动前,也要把master的 jmeter-server.bat运行,这样master也能和其他slave一起执行测试计划了。

    引 http://www.cnblogs.com/puresoul/p/4844539.html ; https://www.cnblogs.com/fengpingfan/p/5583954.html

  • 相关阅读:
    iBatis查询时报“列名无效”无列名的错误原因及解决方法
    【转】Spring结合Quartz实现多任务定时调用
    关于jar中读取包内和包外文件
    【摘自百度文库】数据库水平切分的实现原理解析
    web.xml 中的listener、 filter、servlet 加载顺序及其详解(转载)
    EL表达式
    【转】使用XFire+Spring构建Web Service
    慎用href="javascript:void(0)"
    POI导出EXCEL【摘自:oschina.net】
    【转】IBM websphere6.1 不支持泛型、intInteger类型的自动装箱和拆箱问题
  • 原文地址:https://www.cnblogs.com/houzhizhe/p/7504081.html
Copyright © 2011-2022 走看看