`

[dubbo] resteasy 调用流程分析

阅读更多
在看 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 协议本质上是一样的,只是说有人喜欢在骨架上贴上不同的膜.

0
1
分享到:
评论

相关推荐

    Dubbo调用java接口程序

    以上就是使用Dubbo调用Java接口的基本流程。在实际开发中,还需要考虑服务的版本管理、接口参数校验、异常处理等高级特性,以及如何在微服务环境中有效地使用Dubbo来构建高可用、高并发的分布式系统。对于初学者,...

    Dubbo 实现远程调用

    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异步调用的优化

    对原有的dubbo远程调用的异步的缺陷性进行了优化方案

    针对dubbo分布式调用链系统实现 3

    针对dubbo分布式调用链系统实现_3

    Dubbo异步调用的优化共20页.pdf.zip

    2. **Dubbo的异步模型**:分析Dubbo内部如何实现异步调用,包括Future和Callback机制,以及它们在服务调用中的作用。了解这些机制有助于开发者更好地设计和优化服务。 3. **配置异步调用**:讲解如何在Dubbo服务...

    dubbo提供与调用

    Dubbo是中国阿里巴巴开源的一款高性能、轻量级的Java服务治理框架,它主要负责服务的发布、发现、调用以及监控。在"**dubbo提供与调用**"这个主题下,我们将深入探讨Dubbo的核心概念、配置文件以及Web配置。 1. **...

    dubbo调用的例子

    四、Dubbo服务调用流程 1. **服务注册与发现**:服务提供者启动后,会向注册中心(如Zookeeper)注册自己的服务信息,包括服务接口、地址等。 2. **消费者订阅**:服务消费者启动时,会向注册中心订阅感兴趣的服务...

    nodejs使用原生的dubbo协议打通了dubbo的rpc方法调用.

    标题中的“nodejs使用原生的dubbo协议打通了dubbo的rpc方法调用”意味着在Node.js环境中,开发者成功地实现了对Dubbo服务的RPC(远程过程调用)访问,利用了Dubbo协议的特性。Dubbo是阿里巴巴开源的一个高性能、轻量...

    Spring整合dubbo服务调用(Maven项目)

    【Spring整合Dubbo服务调用(Maven项目)】 在现代企业级应用开发中,Spring框架以其强大的功能和灵活的扩展性被广泛应用,而Dubbo作为阿里巴巴开源的高性能服务框架,常用于实现微服务间的通信。本项目是关于如何在...

    5-42 业务系统集成Dubbo异步调用实现(2).mp4

    5-42 业务系统集成Dubbo异步调用实现(2).mp4

    针对dubbo分布式调用链系统实现 1

    针对dubbo分布式调用链系统实现_1

    针对dubbo分布式调用链系统实现 4

    针对dubbo分布式调用链系统实现_4

    针对dubbo分布式调用链系统实现 5

    针对dubbo分布式调用链系统实现_5

    针对dubbo分布式调用链系统实现 6

    针对dubbo分布式调用链系统实现_6

    dubbo服务调用

    在本文中,我们将深入探讨如何利用 Dubbo 实现服务调用,并了解其超时、重试、服务降级和服务熔断等关键特性。 1. **服务调用** 在 Dubbo 中,服务调用是通过服务接口来完成的。服务提供者暴露服务接口,而服务...

    Dubbo+zookeeper调用java接口

    在IT行业中,分布式服务框架是构建大型复杂系统的关键技术之一,Dubbo作为阿里巴巴开源的一款高...开发者可以通过分析和运行这个案例,深入了解Dubbo和Zookeeper的协同工作原理,为实际项目中的服务治理打下坚实基础。

    Dubbo源代码分析之远程调用过程(2.5.4开发版)

    该文档分析了 Dubbo 框架中 RPC 调用的整个流程,并基于源代码按照执行 时序进行说明,源码版本为2.5.4开发版。 涉及的关键点包括:Invocation、Invoker、Directory、路由、负载均衡、集群容错、过滤器以及监控模块...

Global site tag (gtag.js) - Google Analytics