在看 dubbo rest 协议的时候,很多东西都不是很懂,特别是看测试用例的时候,例如这个:
public void testRestProtocol() {
URL url = URL.valueOf("rest://127.0.0.1:5342/DemoService1/rest/say?version=1.0.0&interface=org.apache.dubbo.rpc.protocol.rest.DemoService");
DemoServiceImpl server = new DemoServiceImpl();
ProviderModel providerModel = new ProviderModel(url.getPathKey(), server, DemoService.class);
ApplicationModel.initProviderModel(url.getPathKey(), providerModel);
Exporter<DemoService> exporter = protocol.export(proxy.getInvoker(server, DemoService.class, url));
Invoker<DemoService> invoker = protocol.refer(DemoService.class, url);
Assertions.assertFalse(server.isCalled());
DemoService client = proxy.getProxy(invoker);
String result = client.sayHello("haha");
Assertions.assertTrue(server.isCalled());
Assertions.assertEquals("Hello, haha", result);
invoker.destroy();
exporter.unexport();
}
是不是很奇怪?我们一般使用的时候调用路径都是严格按照在@Path 注解上的路径来的,原始的 dubbo 测试用例中的路径是这样的:
rest://127.0.0.1:5342/DemoService/rest/say?version=1.0.0&interface=org.apache.dubbo.rpc.protocol.rest.DemoService
经过测试,发现这两种方式都能调用通,当时我就懵逼了,以为 dubbo 中出现了 bug.
于是开始调试代码,发现 RestProtocol 在调用 refer 方法的时候,使用了代理,这个和我们以前的那种方式不同,以前我也使用过 resteasy,比如说我要访问 http://abc/def,直接这么调用就好了,但是 dubbo 在集成 resteasy 的时候是不一样的.
下面说下结论吧. 经过调试得出的结论是和 /DemoService1 还是 DemoService2,还是3没有关系,最主要的还是 @Path 上的注解. 但是有人是不是想说我们调用的路径中没有 DemoService 啊?那它是如何完成调用的了?
答案还是代理,代理会在最终发起 http 请求的时候,使用的 path 是这样的:
http://127.0.0.1:5342/DemoService1/rest/say/DemoService/say
上面的 url 后面的一节是 resteasy 通过代理自动的帮我们干的,到此就回到了以前使用 resteasy 的流程了.
后面说下比如说我们发起一个调用的时候,例如:
http://127.0.0.1:5342/DemoService1/rest/say/DemoService/say
的时候,resteasy 具体帮我们干了啥
1.首先,在部署的时候,解析实现类实现的接口上的注解,将路径和方法一一对应.
2.在发起http 请求后,通过路径去匹配对应的方法,并完成调用.
其实这一套思路和 dubbo 中的 http 协议本质上是一样的,只是说有人喜欢在骨架上贴上不同的膜.
分享到:
相关推荐
Dubbo调用java接口程序
1、Dubbo 远程调用实现 2、内带zookeeper-3.4.5消息服务 3、直接导入myeclipse运行:dubbo-server导入tomcat中运行 4、dubbo-client 运行测试类/dubbo-client/src/com/fengjx/main/Consumer.java
dubbo服务端可以定义其接口、以便其他dubbo客户端调用其接口方法。
对原有的dubbo远程调用的异步的缺陷性进行了优化方案
针对dubbo分布式调用链系统实现_3
dubbo提供与调用方配置文件,及web配置,涉及主要用于dubbo
Dubbo异步调用的优化共20页.pdf.zip
nodejs 使用原生的 dubbo (dubbo head hessian body) 协议打通了 dubbo 的 rpc 方法调用 .
5-42 业务系统集成Dubbo异步调用实现(2).mp4
针对dubbo分布式调用链系统实现_1
针对dubbo分布式调用链系统实现_4
针对dubbo分布式调用链系统实现_5
针对dubbo分布式调用链系统实现_6
该文档分析了 Dubbo 框架中 RPC 调用的整个流程,并基于源代码按照执行 时序进行说明,源码版本为2.5.4开发版。 涉及的关键点包括:Invocation、Invoker、Directory、路由、负载均衡、集群容错、过滤器以及监控模块...
dubbo实现服务调用、超时、重试、服务降级、服务熔断的功能。
spring-cloud-alibaba+dubbo+nacos内部服务调用
包含服务提供者模块dubbo-producer,服务消费者模块dubbo-consumer。先启动dubbo-producer,然后启动dubbo-consumer,测试接口地址为:http://localhost:8004/order/getCustomerName?
增加依赖:通过调用maven命令,下载jar包和热加载到系统,主要用来分析接口方法参数,主要作用在普通模式。 依赖列表:通过分析pom文件,展示已经加载的jar包。 其它特性 springboot 整合 redis,支持spring el ...