Dubbo

一 dubbo缓存

    zookeeper宕掉,会从缓存中读取。

    zookeeper会定期更新缓存。

 

二 dubbo支持的容器

spring容器,logj容器, jetty容器

 

三 dubbo多协议支持

RMI

HESSIAN/webService/http/thrift/dubbo

 

四 多注册中心

 

五 集群模式

将服务多服务器部署,进行负载均衡(策略:轮询,随机,最小活跃度,hash)

 

六 配置

1,服务端,配置bean,暴露服务

2.客户端,引用服务

 

使用方式:1.配置文件 2.注解

 

七 多版本支持:暴露不同的版本

 

八 主机绑定

 

九 容错机制

failsafe:失败安全,吞掉错误,重发

failover(默认):失败,重试其他服务器  retries(重试次数,默认为2,不包含第一次)

failfast:失败后立即报错

failback:失败后自动恢复

forKing:forks设置并行数

broadcast:广播,任意一台报错,则执行的方法报错

 

配置:cluster="策略名称"

 

 

十 配置优先级别原则:1.级别从高到低:方法-接口-全局配置

2.客户端由于服务端

retires(重试),loadBalance(负载),cluster(容错--客户端),timeout(时长--服务端)

 

十一   服务降级(保证核心服务可用,容错是降级的一种)

方式:关闭一些服务,释放一些资源,保证核心服务可用

方法:自动降级(报错直接返回默认数据),人工降级(提前关非核心服务,配置一个开关),

限流(超过峰值--给一个友好提示)

 

dubbo服务降级方式:mock(客户端策略)--报错直接执行mock方法(一些友好提示)

 

 

十二 SPI机制:动态加载

java SPI:  1.META-INF/services/接口全路径文件

dubbo SPI :1.META-INF/dubbo   /META-INF/internal:?META-INF/services

2.文件名(全路径  )  内容: key=value

07-15
Apache Dubbo 是一款高性能、轻量级的开源分布式 RPC(Remote 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配置文件指定具体的服务参数设置。
评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值