51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1615|回复: 2
打印 上一主题 下一主题

【转】Jmeter分布式测试

[复制链接]
  • TA的每日心情
    无聊
    前天 09:05
  • 签到天数: 1050 天

    连续签到: 1 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2016-7-12 15:01:06 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    转自:博客园
    一、Jmeter分布式执行原理:
      1、Jmeter分布式测试时,选择其中一台作为调度机(master),其它机器做为执行机(slave)。
      2、执行时,master会把脚本发送到每台slave上,slave 拿到脚本后就开始执行,slave执行时不需要启动GUI,我理解它应该是通过命令行模式执行的。
      3、执行完成后,slave会把结果回传给master,master会收集所有slave的信息并汇总。

    二、执行机(slave)配置:
      1、slave机上需要安装Jmeter,最好同一版本的Jmeter
      2、添加环境变量:JMETER_HOME=D:\B_TOOLS\apache-jmeter-2.13,此处为你Jmeter的路径(不添加也行)
      3、启动bin目录下的:jmeter-server.bat,启动成功如下图:
      
      4、上图上标红的IP和端口会在master里配置时用到。IP就是slave机器IP,端口默认是1099,端口也可以自定义,这里我自定义为1000,这个后面会讲。
      5、多台slave的话,重复1~4步骤就好。  

    三、调度机(master)配置:
    1、脚本:简单的一个访问百度的脚本: 
      
    2、找到Jmeter的bin目录下jmeter.properties文件,修改如下配置,IP和Port是slave机的IP以及自定义的端口(这里端口我自定义为100,后面会讲如何自定义):
            remote_hosts=10.13.223.202:1000,10.13.225.12:1000
    多台slave之前用","隔开,我这配置了2台,可以看到标红的这个就是上面截图slave的IP和Port.
    3、打开Jmeter,选择运行,有运程启动、运程全部启动两个选项:
      
    4、选择远程启动-->10.13.225.12:1000
        a) master结果,这里我只启动了10.13.225.12:1000这一台slave,所以只有一个结果(线程数和循环次数都是1):
      
        b) slave控制台信息:
      
      5、选择远程启动-->远程全部启动:
        a) master结果,全部启动,我配置了2台slave,所以有两次执行结果:
      

    四、自定义端口:
    上面其实已经实现了Jmeter的分布式测试,这部分主要介绍下如何自定义slave端口:
      1、slave:在slave机的Jmeter的bin目录下,找到jmeter.properties文件,修改如下两个配置项,比如我这里修改为1888:
         server_port=1888
         server.rmi.localport=1888
    2、启动slave机上的jmeter-server.bat,如下图,端口已经修改为:1888
      
    3、master:修改master机器的jmeter.properties文件:
         remote_hosts=10.13.223.202:1000,10.13.225.12:1888
      4、重启jmeter.bat,如下图,端口已经变了:
      
    五、
           有时代理的机器太少,仍不能满足需要,则需要将作为Controller的电脑也当作Agent,则同样需要修改JMeter.properties文件,将Controller的IP和端口加入。这时,需要打先打开Controller电脑中JMeter下bin目录下的jmeter-server.bat,然后再打开JMeter.bat,此时,进入Run -> Remote Start菜单,可以看到Controller也作为远程机器进行运行。

    五、其它说明:
      1、调度机(master)和执行机(slave)最好分开,由于master需要发送信息给slave并且会接收slave回传回来的测试数据,所以mater自身会有消耗,所以建议单独用一台机器作为mater。
      2、参数文件:如果使用csv进行参数化,那么需要把参数文件在每台slave上拷一份且路径需要设置成一样的。
      3、每台机器上安装的Jmeter版本和插件最好都一致,否则会出一些意外的问题。
            4、测试时,从机需打开Jmeter-server.bat服务。

    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏1
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    2018-8-27 15:56
  • 签到天数: 322 天

    连续签到: 1 天

    [LV.8]测试军长

    2#
    发表于 2016-7-13 10:29:25 | 只看该作者
    好东西,顶一个
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    3#
    发表于 2016-7-13 11:08:21 | 只看该作者
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-23 08:38 , Processed in 0.063988 second(s), 22 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表