由telnet调用Dubbo引发的思考
2017-09-14 00:00
316 查看
一、简要说明
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解脱出来,就更加好了
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 接口
- 回调机制引发的调用思考
- Child类调用GrandFather类方法引发的思考
- String方法调用面试题引发的思考
- Child类调用GrandFather类方法引发的思考
- 远程调用引发的思考
- 模拟dubbo 框架RPC调用及dubbo的服务动态注册,服务路由,负载均衡功能的思考
- 由显式调用析构函数引发的思考
- Beego框架的一条神秘日志引发的思考
- C# 调用C++dll 引发DllNotFoundException
- 一个JavaScript问题引发的思考
- TreeView控件失效引发的思考
- 关于馒头血案引发的法律相关的思考
- 年轻女子胃溃疡大出血引发的思考
- 远程调用框架dubbo原理
- vmware中如何检查cpu的使用状况-一个考题引发的思考
- tomcat环境中file.encoding引发的思考
- 1*1 引发的思考
- 【CSS】由 flex: 1; 引发的思考
- 不同机器互相调用WebService或者HTTP一定要telnet 测试