文章目录
dubbo
概念
dubbo是阿里巴巴旗下的基于java的高性能RPC分布式框架。核心组件包括:
-
远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。
-
集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。
作用
-
服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。
采用全spring配置方式,透明化接入应用,只需要简单的配置,对于应用没用任何API的入侵,用spring加载dubbo的配置即可
dubbo内置容器
- Spring Container
- Jetty Container
- Log4j Container
核心配置
配置 | 配置说明 |
---|---|
dubbo:service | 服务配置 |
dubbo:reference | 引用配置 |
dubbo:protocol | 协议配置 |
dubbo:application | 应用配置 |
dubbo:module | 模块配置 |
dubbo:registry | 注册中心配置 |
dubbo:monitor | 监控中心配置 |
dubbo:provider | 提供方配置 |
dubbo:consumer | 消费方配置 |
dubbo:method | 方法配置 |
dubbo:argument | 参数配置 |
集群容错方案
集群容错方案 | 说明 |
---|---|
Failover Cluster | 失败自动切换,自动重试其他服务器 (默认) |
Failfast Cluster | 快速失败,立即报错,只发起一次调用 |
Failsafe Cluster | 失败安全,出现异常时,直接忽略 |
Failback Cluster | 失败自动恢复,记录失败请求,定时重发 |
Forking Cluster | 并行调用多个服务器,只要一个成功返回即可 |
broadcast Cluster | 广播逐个调用所有提供者,任意一个报错即报错 |
负载均衡策略
负载均衡策略 | 说明 |
---|---|
Random LoadBalance | 随机,按权重设置随机概率 |
RoundRobin LoadBalance | 轮询,按公约后的权重设置轮询比率 |
LeastActive LoadBalance | 最少活跃调用,相同活跃数的随机 |
ConsistentHash LoadBalance | 一致性Hash,相同参数的请求总是发到同一个提供者 |
通信框架
默认使用Netty框架,集成有Mina、Grizzly
dubbo与SpringCloud
dubbo优势:
- 单一应用架构:系统压力小时,一个应用就可以将所有功能部署在一起,节省成本,部署节点少
- 垂直应用架构:访问量大时,将应用拆开,提升效率
- 分布式服务架构:垂直应用增加时,将核心业务抽取出来独立,形成稳定的服务中心。
SpringCloud优势:
比较:
- dubbo使用二进制传输,占用的带宽更少。
- SpringCloud使用http传输,带宽消耗较大。
- dubbo的jar包依赖处理起来很麻烦
- dubbo的注册中心可选zk,redis等,SpringCloud的注册中心只能是eureka或者自研
- SpringCloud的接口协议约定比较自由,需限制接口无序升级
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。