本篇文章给大家谈谈jmeter dubbo接口测试配置,以及对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
今天给各位分享jmeter dubbo接口测试配置的知识,其中也会对进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
关于jmeter测试dubbo接口方式
本文章介绍如何使用jmeter测试dubbo接口,涉及如下两种方式
1.使用官方dubbo版本包测试dubbo接口
2.通过自己编写java请求插件,实现dubbo调用
选择方式1或方式2并没有什么区别,取决于部分自研公司对dubbo进行了封装,导致官方提供的dubbo包并不适用于方式1,则可以通过方式2去调用
https://github.com/ningyu1/jmeter-plugins-dubbo/releases
解压tar将获取到的jar包放入${JMETER_HOME}\lib\ext路径下(这里获取到的jar包为jmeter-plugins-dubbo-2.7.1-jar-with-dependencies),重启jmeter应用(这里重启完应用会添加取样器会多出一个dubbo sample)
右键添加,选择线程-线程组
2.光标对准线程组右键添加-取样器-dubbo sample
此处需要关注,当方法接收的是一个String,或者List等类型的参数,可参照截图配置
那么当方法接收的参数是一个对象时,需要获取对接接口的api jar包并关联到当前测试计划
选中测试计划,点击下方浏览按钮,选择对应的jar包
传参的具体方式可参照如下
接口1返回:
接口2返回
看了下网上的大多请求都是单接口请求dubbo,这样就会导致,每次有新的接口的时候都得去更新新的请求,这里提供一个一劳永逸的方法,通过泛化调用,实现一个jar请求可适配所有接口,一般看到这个文章的可能大多都是测试的同学,对于当前方法需要对java有一定的基础,所以这个时候就体验到学习的重要性了,下面开始操作吧
file-new-project,选择maven
输入组织-坐标后点击next
按需配置名称路径后点击finsh
pom.xml配置如下
实现方式如下
打包操作
左侧窗口为生成的jar包和lib目录
这里要说明下,网上提供了一种方式,通过修改安装目录bin下jmeter.properties文件关联lib下的依赖
文件中增加如下(通过尝试,这么做会导致jmeter启动由于jar包加载顺序的问题,ui部分控件不可用)
这里我使用的是另一种更为简便的方式
将原安装目录lib下ext修改为extbak
新建ext,并将工程lib下的jar包和dobbo-jmeter-interface-1.0-SNAPSHOT.jar放入之
由于可能会用到随机函数,从extbak获取ApacheJMeter_functions.jar,也放入到新建的ext目录下
重启jmeter,稍等片刻
添加java请求
添加结果树
点击运行后,结果树信息如下
后续可自行配置断言和随机参数等
jmeter远程分布式调用配置记录
最近在给产品线做基于dubbo协议的java服务测试,
jmeter dubbo接口测试配置我本机没有配置dubbo服务容器,先让同事提供测试类,我再对测试类工程导入jmeter的jar包,封装成jmeter可执行的jar包。基于本次性能测试的要求,要把脚本放在linux下部署好了 dubbo服务的机器上测试,多次尝试后选择了用jmeter远程分布式调用的方式。
jmeter远程分布式调用,可以使用本机做控制端,其
jmeter dubbo接口测试配置他已经搭建好dubbo协议的电脑或者linux服务器做测试服务端
配置要求是两台windows机(ip
jmeter dubbo接口测试配置:134.33.***.170:1888,134.22.***.20:1899)和linux服务器(ip:130.17.***.129:2099)都使用相同版本的jmeter,本次测试使用的是apache-jmeter-3.1
首先配置window控制端修改jmeter.properties,在remote_hosts=添加远程服务端地址和端口
其次配置windows服务端 修改jmeter.properties,取消server_port=1899和server.rmi.localport=1899前面的注释,设置远程端口为1899,默认为1099,建议修改一个其
jmeter dubbo接口测试配置他数值。
启动jmeter_server会显示一个
这里的ip地址就是和控制端配置的remote_hosts一致。
报错问题记录:
1、配置完成后测试提示connnection refused 原因是:服务端的防火墙为关闭,禁止访问,关闭防火墙就可以ping通
2、可以访问后再测试提示:
原因就是如果服务端的jmeter.properties中的server_port和server.rmi.localport端口未指定,打开jmeter_server后端口是变化的无法捕捉。
接下来配置linux服务器的jmeter.properties的server_port=2099和server.rmi.localport=2099。在/apache-jmeter-3.1/bin下执行./jmeter_server提示endpoint为127.0.0.1:2099,控制端调用的时候提示
查找原因如下:服务器配置了双网卡,内外网的隔离,jmeter在启动时会优先找内网地址,不识别配置的服务器地址,修改方法如下:修改/ossapp/apache-jmeter-3.1/bin下的jmeter_server文件修改RMI_HOST_DEF=-Djava.rmi.server.hostname=130.17.**8.129保存。在windows控制端重新测试,完美执行,监控linux下日志
Dubbo配置参数详解-generic
画外音jmeter dubbo接口测试配置:目前Dubbo在开源中国举办jmeter dubbo接口测试配置的2019年度最受欢迎中国开源软件中排名第3名jmeter dubbo接口测试配置,支持Dubbo的朋友可以去投票哇。 2019年度最受欢迎中国开源软件
Consumer端正常调用Dubbo服务时jmeter dubbo接口测试配置,一般都需要服务提供方提供一个jar包,只有在项目中引入该jar包,才能调用相关服务;能不能向http调用那样,我只需要知道我要调用的url就可以直接调用Dubbo服务?
有的,这就是generic做的事。
generic :通用服务调用,当我们已经知道我们要调用的服务的全限定名及方法,就不需要服务提供者的jar就能调用Dubbo服务了。
generic要配合interfaceName参数一起使用,其中interfaceName是Dubbo服务的全限定名,比如:
当provider接收到请求时,会调用一系列的过滤器对请求进行处理,这其中就包含处理generic的过滤器: GenericFilter
该过滤器会判断调用的方法是否是$invoke,如果是则会通过反射调用正在的方法
笔者认为该参数最大的用武之地是作为网关使用,笔者所在公司的网关就提供了http转换成dubbo接口调用的功能,前端使用http调用,后端使用dubbo服务进行处理;网关提供一个接口配置页面,只需要业务方在页面配置url与dubbo接口的转换关系即可,网关不需要引用服务提供者的jar包,如果接口有变动,网关无需知道,只要业务方修改配置即可。
dubbo接口调用总结
1、需要知道对应的接口名称和调用方法名称,可以找开发要
2、需要配置nacos注册中心,可以找开发要地址
4、在工具中设置版本号
5、dubbo接口调用参数类型对照表:
https://github.com/thubbo/jmeter-plugins-for-apache-dubbo/wiki/ParameterComparisonTable
6、dubbo接口复杂情况调用方式:
https://github.com/thubbo/jmeter-plugins-for-apache-dubbo/wiki/FAQ
关于jmeter dubbo接口测试配置和的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
jmeter dubbo接口测试配置的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于、jmeter dubbo接口测试配置的信息别忘了在本站进行查找喔。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
暂时没有评论,来抢沙发吧~