可视化Dubbo测试工具iubbox 2.0版本发布啦

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 Tair(兼容Redis),内存型 2GB
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
简介: 可视化Dubbo测试工具iubbox 2.0版本发布啦

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



dubbo接口调试复杂,需要通过telnet命令或者通过consumer调用来触发。

telnet语句参数格式复杂,每次编写都要小心谨慎,一旦出错又需重来。

复杂对象参数传参调用接口复杂,编写java api调用接口时间成本较高。



上述这些坑我在工作中都有遇见过,发现大部分耗时都会卡在调用dubbo服务做自测的阶段,所以后来花费了写业余时间写了一款高效的dubbo测试工具开源给大家使用。

这款工具目前已在实际工作中应用半年多,基本功能已经成熟,后续依旧会进行版本维护。

相关的代码地址为:



gitee.com/IdeaHome_ad…

ps: 如果大家喜欢,希望能给出一颗宝贵的star


2.0.0-release版本


下边部分是针对于2.0.0-release版本进行迭代之后的使用说明文档

\

关于如何部署本工具


\

新版本的代码结构去除了原先的前后端分离,采用前后端合并的思路进行整合,减轻使用者的部署成本。


前端代码的部署


前端采用非常简单的vue技术,只需要调整js目录下方的constants.js文件中的server_addr变量即可改变请求地址。


默认的请求地址为:


let server_addr="http://127.0.0.1:7090/";
复制代码


后端代码的部署


后端工程采用了springboot框架技术,核心的配置放在了application.properties里面,调整为对应的redis数据库或者mysql配置即可


server.port=7090
application.invoker.name=iubbo-invoker-proxy
spring.datasource.druid.password=password
spring.datasource.druid.username=root
spring.datasource.druid.url=jdbc:mysql://10.11.9.243:3306/iubbox
spring.datasource.druid.driver-class-name=com.mysql.jdbc.Driver
mybatis-plus.configuration.map-underscore-to-camel-case=true
spring.redis.port=6379
spring.redis.host=localhost
spring.redis.password=password
复制代码


然后导入建表的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 CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB  AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COLLATE=utf8mb4;
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 CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COLLATE=utf8mb4;
CREATE TABLE `t_register_config` (
  `id` int(6) NOT NULL AUTO_INCREMENT,
  `host` varchar(255) DEFAULT NULL COMMENT 'host地址',
  `ip` varchar(60) DEFAULT NULL COMMENT '注册中心真实ip',
  `create_time` datetime DEFAULT CURRENT_TIMESTAMP,
  `update_time` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `type` smallint(2) DEFAULT NULL COMMENT '注册中心类型:1 zk,2 nacos',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;
复制代码


t_user 用于记录相关的用户账号,方便于保存用户账号信息。


t_dubbo_invoke_req_record 用于记录请求dubbo接口的用例信息。


t_register_config 用于记录注册中心的配置信息


最后就是启动入口类org.iubbo.proxy.DubboInvokerApplication


启动成功截图


网络异常,图片无法展示
|


关于本工具的使用教程



本工具区分了已登录账号和未登录账号两类角色,已登录账号的使用者可以对请求的用例进行保存,方便下一次提取信息,未登录账号虽然没有保存用例的功能,但是不影响其使用本工具进行测试。


首页地址:

http://localhost:7090/html/test-dubbo-web.html


或者访问:

http://localhost:7090/html/index.html


首页截图:

网络异常,图片无法展示
|


ps:2.0.0版本对颜色做了一些细微调整,如果觉得绿色太丑,可以在代码里面进行调整


1.指定zk注册地址


2.0.0版本中将注册中心的配置抽离为通过MySQL进行管理:

只需要在t_register_config表里面加入一行记录即可看到相关信息:


网络异常,图片无法展示
|


在测试dubbo接口之前,我们通常都会去拉取一遍zk上边的service地址,操作如下图:

先在文本框点击,输入和js配置有关的字母或数字会有模糊匹配的选项供各位选择:


网络异常,图片无法展示
|


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


拉取zk地址的时候,后端会根据文章上边提到的js配置里面的ip值去拉取,拉取成功会有相关提示:


网络异常,图片无法展示
|


接下来便是筛选dubbo服务地址的功能,在拉取zk地址下方有一个下拉框,这里面此时应当会被注入zk上所有dubbo服务列表的名称。


网络异常,图片无法展示
|


选择对于的service名称,然后在右边的“请输入名称”文本框中输入该接口对应的方法名称(一定要名称对应)


例如测试该方法:


public interface DubboService {
    /**
     * 测试接口功能
     *
     * @return
     */
    String doTest(String str);
}
复制代码


然后配置相关的参数和名称:


选择对应参数类型和值:


网络异常,图片无法展示
|


选择参数之后需要点击一遍添加参数按钮,这样才能保证刚才设置的参数生效。

最后发起请求:


网络异常,图片无法展示
|


在基础参数配置项的旁边,还有一个模块是专门配置consumer端的额外内容,这些参数项都是在平时工作中可能会应用到的场景,需要的时候可以进行配置。这里面也配备了工作中非常常用的直连选项。


额外参数


个人最喜欢使用的还是直连功能,因为在开发过程中,经常需要直连机器做自测:


网络异常,图片无法展示
|


假如说希望保存自己曾经发送过的dubbo测试用例,那么你只需先进行登录账号,或者点击注册按钮重新注册账号即可:


网络异常,图片无法展示
|


网络异常,图片无法展示
|


保存请求用例


网络异常,图片无法展示
|


查看保存用例信息


用户手动刷新下页面才能显示保存的用例信息:


网络异常,图片无法展示
|


点击选用参数,则页面又会重新回显之前使用过的请求信息。


转让测试用例



点击转让测试用例按钮即可进行用户的转让


网络异常,图片无法展示
|


压力测试


支持对于dubbo接口进行压力测试的配置


网络异常,图片无法展示
|


请求详情分析


对于每次dubbo请求,都会有对应的参数请求信息,响应数据相关信息展示:

接口响应数据信息:


网络异常,图片无法展示
|


实际发送给dubbo服务端的各项参数指标信息:


网络异常,图片无法展示
|


请求耗时的各项指标数据


网络异常,图片无法展示
|


特殊参数请求


该工具支持多种开发中常见的参数格式调用,目前支持常规参数

ps:注意这里的参数格式需要和dubbo方法里面的参数格式按照相同顺序相同类型做映射,否则后端程序会返回找不到对应方法


Java的常用基本类型数据:boolean,short,int,long,double,char,float

Java中常用的包装类数据:


java.lang.String,
java.lang.Integer,
java.lang.Object,
java.util.List,
java.lang.Class,
java.lang.Long,
java.lang.Boolean,
java.util.Map,
java.util.Date,
java.lang.Float,
java.lang.Double
复制代码


对于简单的数据类型传递


网络异常,图片无法展示
|


多参数,中英文混合传递


网络异常,图片无法展示
|


List类型参数的传递


网络异常,图片无法展示
|


Class类型的参数传递


网络异常,图片无法展示
|


Map类型的参数传递


网络异常,图片无法展示
|


Date类型的参数传递


网络异常,图片无法展示
|


自定义对象参数传参


如果在实际应用中遇到了这种场景,需要调用以下的接口,那么这个使用就需要使用自定义参数了:


网络异常,图片无法展示
|


网络异常,图片无法展示
|


网络异常,图片无法展示
|


复杂类型自定义参数传递


假设遇到了List类型参数,而且传输的List里面包含有自定义对象,例如下边这种类型:


List<UserDTO> testUserDtoList(List<UserDTO> userDTOList,Class clazz);
复制代码


那么此时的传参案例可以像下边这样来写:


网络异常,图片无法展示
|


易错点归纳


注意请求的参数顺序要和方法对应的参数顺序一致,假设服务的方法定义如下:


<T> List<T> getList(List<Long> var1, Class<T> var2);
复制代码


那么传入的参数就必须先填List参数,再写Class参数。


正确示例: (先写了List参数,再写Class参数)

错误示例: (先写了Class参数,再写List参数)


实际运行:

目前该工具已经在自己公司运行一年左右,较为平稳,给团队的开发效率带来了极大地提升。希望本工具也能对各位有所帮助。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
8月前
|
Dubbo Cloud Native Java
干翻Dubbo系列第二篇:Dubbo3相对其他版本的升级
干翻Dubbo系列第二篇:Dubbo3相对其他版本的升级
|
JavaScript Dubbo 应用服务中间件
Apache Dubbo 首个 Node.js 3.0-alpha 版本正式发布
本文分享了 Dubbo3 Node.js 首个正式版本,演示基于 Triple 协议的 RPC 通信模式,包括代码生成、服务发布和服务访问等过程。
|
7天前
|
数据采集 人工智能 自然语言处理
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
Midscene.js 是一款基于 AI 技术的 UI 自动化测试框架,通过自然语言交互简化测试流程,支持动作执行、数据查询和页面断言,提供可视化报告,适用于多种应用场景。
91 1
Midscene.js:AI 驱动的 UI 自动化测试框架,支持自然语言交互,生成可视化报告
|
2月前
|
Dubbo 安全 应用服务中间件
Apache Dubbo 正式发布 HTTP/3 版本 RPC 协议,弱网效率提升 6 倍
在 Apache Dubbo 3.3.0 版本之后,官方推出了全新升级的 Triple X 协议,全面支持 HTTP/1、HTTP/2 和 HTTP/3 协议。本文将围绕 Triple 协议对 HTTP/3 的支持进行详细阐述,包括其设计目标、实际应用案例、性能测试结果以及源码架构分析等内容。
|
3月前
|
Dubbo IDE Java
dubbo学习二:下载Dubbo-Admin管理控制台,并分析在2.6.1及2.6.1以后版本的变化
这篇文章是关于如何下载和部署Dubbo管理控制台(dubbo-admin)的教程,并分析了2.6.1版本及以后版本的变化。
110 0
dubbo学习二:下载Dubbo-Admin管理控制台,并分析在2.6.1及2.6.1以后版本的变化
|
Dubbo 应用服务中间件 API
Go语言微服务框架重磅升级:dubbo-go v3.2.0 -alpha 版本预览
随着 Dubbo3 在云原生微服务方向的快速发展,Dubbo 的 go 语言实现迎来了 Dubbo3 版本以来最全面、最大幅度的一次升级,这次升级是全方位的,涉及 API、协议、流量管控、可观测能力等。
|
7月前
|
前端开发 Java Maven
dubbo-admin安装(分离版本)
dubbo-admin安装(分离版本)
|
8月前
|
传感器 数据可视化 算法
LabVIEW开发光线追踪可视化分段反射器测试台
LabVIEW开发光线追踪可视化分段反射器测试台
55 3
|
8月前
|
数据可视化 数据挖掘 Java
springboot+vue体质测试数据分析及可视化设计(源码+文档)
体质测试数据分析及可视化设计实现了以下功能: 管理员:首页、个人中心、学生管理、教师管理、日常运动管理、运动分析管理、成绩信息管理、论坛管理、系统管理, 学生:首页、个人中心、日常运动管理、运动分析管理、成绩信息管理、论坛管理, 教师:首页、个人中心、日常运动管理、运动分析管理、成绩信息管理、系统管理, 前台首页:首页、论坛信息、公告信息、个人中心、后台管理、客服模块的修改维护操作。
|
8月前
|
数据可视化
结构方程模型 SEM 多元回归和模型诊断分析学生测试成绩数据与可视化
结构方程模型 SEM 多元回归和模型诊断分析学生测试成绩数据与可视化