dubbo

本文探讨了在Tomcat中部署Dubbo服务时遇到的问题,包括调用超时及类加载器可见性错误,并提供了相应的解决方案。

把所有公用的jar放入tomcat的lib出现很多问题


1:生成者的jar放入tomcat的lib,消费者没放入

Failed to invoke the method invoker in the service org.agile.apipl.rpc.RpcSoaManager. Tried 3 times of the providers [10.XX.21:20881] (1/1) from the registry 10.XX.25:2181 on the consumer 10.88.6.247 using the dubbo version 2.8.4. Last error is: Invoke remote method timeout. method: invoker, provider: dubbo://10.XX.21:20881/org.agile.apipl.rpc.RpcSoaManager?anyhost=true&application=agile-api-consumer&check=false&dubbo=2.8.4&generic=false&group=account&interface=org.agile.apipl.rpc.RpcSoaManager&methods=singleInvoker,asyncInvoker,invoker&organization=dubbox&owner=programmer&pid=7320&revision=apipl&serialization=kryo&side=consumer&timestamp=1445568766111, cause: Waiting server-side response timeout. start time: 2015-10-23 10:52:53.078, end time: 2015-10-23 10:52:54.079, client elapsed: 0 ms, server elapsed: 1001 ms, timeout: 1000 ms, request: Request [id=2, version=2.0.0, twoway=true, event=false, broken=false, data=RpcInvocation [methodName=invoker, parameterTypes=[class org.agile.apipl.common.context.RainbowContext], arguments=[org.agile.apipl.common.context.RainbowContext@48c36436], attachments={path=org.agile.apipl.rpc.RpcSoaManager, interface=org.agile.apipl.rpc.RpcSoaManager, group=account, version=0.0.0}]], channel: /XXXX:56318 -> /10.XX.21:20881


2:生成者和消费者的jar都放入tomcat的lib

Error creating bean with name 'accountRpc': FactoryBean threw exception on object creation; nested exception is java.lang.IllegalArgumentException: interface org.agile.apipl.rpc.RpcSoaManager is not visible from class loader


解决方法:dubbo-2.8.4.jar别放入tomcat的lib还是在应用的WEB-INF\lib

Apache Dubbo 是一款高性能、轻量级的开源分布式 RPCRemote Procedure Call)框架,最初由阿里巴巴团队开发并贡献给 Apache 基金会。它专注于服务间的远程调用以及服务治理能力,具备良好的可扩展性和灵活性。 ### 架构特点 Dubbo 提供了完整的面向接口代理的服务模型,并支持多种通信协议和序列化方式。其核心组件包括: - **Provider**:暴露服务的一方,负责提供具体的业务功能。 - **Consumer**:调用远程服务的一方,通常作为客户端发起请求。 - **Registry**:注册中心用于存储服务地址和其他元数据,帮助 Consumer 发现 Provider 实例。 - **Monitor**:监控模块收集运行时指标,便于性能分析和服务优化。 - **Protocol & Transport Layer**:定义网络传输层的行为,允许开发者自定义或者集成新的协议[^1]。 ### 使用场景 适用于需要高效处理大量并发请求的企业级应用,尤其是那些依赖于稳定可靠的服务间交互的应用程序。例如,在电商平台中,订单管理系统可以通过 Dubbo 来协调库存系统、支付网关等多个后端服务之间的协作。此外,当企业希望对其内部已有的私有协议进行封装以便更好地融入现代微服务体系时,也可以利用 Dubbo 的插件化设计来达成目标[^2]。 ### 官方文档与社区资源 官方文档位于[dubbo.apache.org](https://dubbo.apache.org),这里不仅包含了详细的API说明和技术指南,还提供了如何快速入门的最佳实践案例分享。除了基础教程外,《分布式服务治理框架Apache Dubbo的学习及应用实战》这本书籍深入探讨了许多高级主题,比如定制化的过滤器链路追踪机制等实用技巧[^3]。而对于想要对比不同微服务技术栈优劣的技术人员来说,《个人学习笔记 - 分布式RPC框架Apache Dubbo》这篇文章则给出了关于为何选择Dubbo而非其他流行方案如Spring Cloud的理由阐述[^4]。 ```java // 示例代码展示了一个简单的服务消费者配置 public class ServiceConsumer { public static void main(String[] args) throws Exception { ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[]{"consumer.xml"}); context.start(); DemoService demoService = (DemoService)context.getBean("demoService"); // 获取远程服务代理 String hello = demoService.sayHello("world"); // 执行远程方法调用 System.out.println(hello); // 输出结果 } } ``` 以上展示了创建一个基本的服务消费者的Java代码片段;实际部署过程中还需要相应的XML配置文件指定具体的服务参数设置。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值