美文网首页
用telnet远程调用dubbo

用telnet远程调用dubbo

作者: jerrik | 来源:发表于2017-09-15 11:15 被阅读0次

一、简要说明

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解脱出来,就更加好了

相关文章

  • 用telnet远程调用dubbo

    一、简要说明 Dubbo从2.0.5以上版本就支持telnet命令,可以查看服务列表,统计次数,查看方法列表,跟踪...

  • 命令行调用Dubbo服务

    Dubbo 服务端支持 telnet 调用,具体如下: telnet 连接到 dubbo 服务端 查看服务端接口列...

  • dubbo use

    一. what is dubbo   dubbo是个rpc框架,核心是远程方法调用。围绕着远程方法调用拓展了:服务...

  • Dubbo面试18问!你会多少?

    dubbo是什么 dubbo能做什么 透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任...

  • Dubbo之使用总结

    dubbo作为一个远程调用框架,dubbo+zookeeper,dubbo作为中间件使用,zookeeper则作为...

  • Dubbo远程调用

    通过代理对象进行远程方法的调用,从大的方面也可以分为三步,分别是代理调用、容错负载和远程通信。 容错负载是Dubb...

  • Dubbo远程调用

    远程调用 服务消费者 Consumer远程调用流程主要可以用一下的这张流程图表示 流程图 主要流程 主要为以下的几...

  • dubbo Serialized class org.apach

    在使用dubbo实现远程调用的过程中,出现了这个错误,原因是,dubbo远程调用的参数类都必须实现序列化。在项目中...

  • 使用 Telnet 调用 Dubbo 服务

    原文地址:https://alphahinex.github.io/2020/10/25/dubbo-telnet...

  • Dubbo的调用栈详细介绍

    Dubbo framework示意图 整个调用过程 (1)protocol 远程调用层:封装 RPC 调用,以 I...

网友评论

      本文标题:用telnet远程调用dubbo

      本文链接:https://www.haomeiwen.com/subject/nzdssxtx.html