开源一款超实用的 Dubbo 测试工具,已用半年,感觉很有feel

不知道你是否在工作中有遇到过类似情况:

  • dubbo接口调试复杂,需要通过telnet命令或者通过consumer调用来触发 。
  • telnet语句参数格式复杂,每次编写都要小心谨慎,一旦出错又需重来 。
  • 复杂对象参数传参调用接口复杂,编写JAVA api调用接口时间成本较高 。
 
上述这些坑我在工作中都有遇见过,发现大部分耗时都会卡在调用dubbo服务做自测的阶段,所以后来花费了写业余时间写了一款高效的dubbo测试工具开源给大家使用 。
这款工具目前已在实际工作中应用半年多,基本功能已经成熟,后续依旧会进行版本维护 。
相关的代码地址为:
https://gitee.com/IdeaHome_admin/dubbo-proxy-tools
ps: 如果大家喜欢,希望能给出一颗宝贵的star
关于如何部署本工具下载了gitlab的代码之后,你会看到有两个文件包:iubbo-proxy和iubbo-proxy-web,它们分别正好对应了后端代码和前端代码 。
开源一款超实用的 Dubbo 测试工具,已用半年,感觉很有feel

文章插图
 
前端代码的部署前端采用非常简单的vue技术,只需要将文件部署到一台Nginx上边即可运作 。前端的默认访问页面是test-dubbo-web.html 。
但是有两个小点需要改动下js配置
constants.js
这份文件里面编写了对应的请求server地址,这块是对应了后端服务的url 。
开源一款超实用的 Dubbo 测试工具,已用半年,感觉很有feel

文章插图
 
由于请求dubbo接口需要通过zk注册中心来拉去服务名列表,所以需要在iubbo.x.js里面的commonzk中做配置:
开源一款超实用的 Dubbo 测试工具,已用半年,感觉很有feel

文章插图
 
这里的host是一个别称,相当于一个key用于供前端展示,实际上传输给后端的是用ip这个值 。
后端代码的部署后端工程采用了springboot框架技术,核心的配置放在了Application.properties里面:
server.port=7089application.invoker.name=iubbo-invoker-proxyspring.datasource.druid.password=spring.datasource.druid.username=spring.datasource.druid.url=jdbc:MySQL://127.0.0.1:3306/iubbox-proxyspring.datasource.druid.driver-class-name=com.mysql.jdbc.Drivermybatis-plus.configuration.map-underscore-to-camel-case=truespring.redis.port=6379spring.redis.host= 127.0.0.1然后倒入建表的sql:
CREATE TABLE `t_dubbo_invoke_req_record` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `user_id` int(11) DEFAULT NULL COMMENT '用户id',  `arg_json` varchar(2500) COLLATE utf8_bin DEFAULT NULL COMMENT 'dubbo请求参数',  `create_time` datetime DEFAULT CURRENT_TIMESTAMP,  `update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;CREATE TABLE `t_user` (  `id` int(9) NOT NULL AUTO_INCREMENT,  `username` varchar(60) COLLATE utf8_bin DEFAULT NULL,  `password` varchar(30) COLLATE utf8_bin DEFAULT NULL,  `createTime` datetime DEFAULT CURRENT_TIMESTAMP,  `updateTime` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
  • t_user 用于记录相关的用户账号,方便于保存用户账号信息 。
  • t_dubbo_invoke_req_record 用于记录请求dubbo接口的用例信息 。
最后就是启动入口类
org.iubbo.proxy.DubboInvokerApplication
启动成功截图
开源一款超实用的 Dubbo 测试工具,已用半年,感觉很有feel

文章插图
 
关于本工具的使用教程本工具区分了已登录账号和未登录账号两类角色,已登录账号的使用者可以对请求的用例进行保存,方便下一次提取信息,未登录账号虽然没有保存用例的功能,但是不影响其使用本工具进行测试 。
首页截图:
开源一款超实用的 Dubbo 测试工具,已用半年,感觉很有feel

文章插图
 
1.指定zk地址
在测试dubbo接口之前,我们通常都会去拉取一遍zk上边的service地址,操作如下图:先在文本框点击,输入和js配置有关的字母或数字会有模糊匹配的选项供各位选择:
开源一款超实用的 Dubbo 测试工具,已用半年,感觉很有feel

文章插图
 
选中了zk地址之后,再去点击拉取zk地址按钮(以前有同事刚接触这个工具的时候,这里被绕蒙了~~)


推荐阅读