用telnet远程调用dubbo

一、简要说明

Dubbo从2.0.5以上版本就支持telnet命令,可以查看服务列表,统计次数,查看方法列表,跟踪调用,查看状态.详细使用请参加dubbo官方手册.这样可以方便测试、调试,实时查看服务结果。确实省去了不少事情,当发现服务有问题时,总不至于还要打开IDE 利用dubbo消费端再来测试吧,这样效率也比较低下。

二、实现简单介绍

了解Netty的人都很清楚,而且很快速的可以搭建一套属于自己的telnet服务,不清楚的可以参考netty入门指南,里面就有讲到如何利用netty搭建一套属于自己的telnet服务.Dubbo的网络底层实现就是Netty,查看源码发现,dubbo的确有自己的telnet包(com.alibaba.dubbo.remoting.telnet),可以自行查看。也就是说dubbo确实监听了telent请求,将指定的命令(ls,invoke等等)转换成特定的执行指令来调用dubbo服务。

输入图片说明
输入图片说明

其具体的入口如图:

输入图片说明
输入图片说明

dubbo的核心加载配置模块就是仿JDK SPI机制,通过telnet输入的指定路由到指定的命令处理器。

三、自己扩展一下

感觉通过命令行调用还是不太智能,每次都需要拷贝包名类名方法名,如果一个基本类型或者string参数还好,如果是很多字段的对象,需要将他转换成json字符串来操作,可想而知,这种纯命令行的操作还是不太人性化。如果仅仅只是查看服务列表和统计次数,还是不错的。下面我主要讲的是 能不能利用dubbo客户端也像调用本地代码一样调用远程服务呢?答案肯定是可行的。

实现机制大概如下:

1.我们只持有dubbo客户端服务,并没有服务的实现,所以必须创建服务的代理来实现方法的拦截来做自己要做的事。

2.利用telnetClient来做输入输出。

3.当调用客户端服务时,我将指定的服务类型和方法参数 拼接成dubbo telnet所希望的样子.

输入图片说明
输入图片说明

四、更进一步

如果想做得更智能,还可以扩展dubbo,暴露出一个更加方便的调用入口,利用spring-shell做成自动完成的那种形式,还可以从IDE解脱出来,就更加好了

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,803评论 19 139
  • 0 准备 安装注册中心:Zookeeper、Dubbox自带的dubbo-registry-simple;安装Du...
    七寸知架构阅读 14,738评论 0 88
  • 木耳炒百合的做法步骤: 1.黑木耳用水浸泡24小时左右泡发,中间换水2-3次,夏天天气太热的话最好放入冰箱泡发 2...
    长相厮守阅读 1,315评论 0 1
  • 一转眼。时间如梭,我升到了高二.原本清闲的日子开始繁忙.天天就是学校家里的来回走动,来不及欣赏晚霞,来不及回顾曾经...
    盛夏如初见阅读 1,733评论 0 3
  • 第一话~荡然无存 火光冲天 林府中黑烟冲天,林若曦呆呆地望着被熏黑的墙壁,如梦如幻,几小时前,她还和父亲兄...
    喵小姐不爱糖果阅读 2,515评论 1 0

友情链接更多精彩内容