一、简要说明
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解脱出来,就更加好了