本文主要是介绍微服务-Dubbo原理探险,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Apache Dubbo 是一款高性能、轻量级的开源服务框架。
一、Dubbo核心能力
1、面向接口代理的高性能RPC调用:服务以接口为粒度,为开发者屏蔽远程调用底层细节。
支持的协议:Triple(Dubbo3)协议、Dubbo2 协议、 gRPC、Thrift、JsonRPC、Hessian2、REST 等。RPC协议规范了数据在网络中的传输内容和格式。
gRPC:基于 HTTP/2 协议,简单、天然有 server push/ 多路复用 / 流量控制能力;基于 Protobuf 的多语言跨平台二进制兼容能力,提供强大的统一跨语言能力;k8s/etcd 等组件的天然支持协议,云原生的事实协议标准。
2、智能负载均衡:内置多种负载均衡策略,智能感知下游节点健康状况,显著减少调用延迟,提高系统吞吐量。
3、服务自动注册与发现:支持多种注册中心服务,服务实例上下线实时感知。
基于消费端的自动服务发现能力,Dubbo3应用级服务发现,Dubbo2x接口级服务发现。
4、高度可扩展能力:遵循微内核+插件的设计原则,所有核心能力如Protocol、Transport、Serialization被设计为扩展点,平等对待内置实现和第三方实现。
5、运行期流量调度:内置条件、脚本等路由策略,通过配置不同的路由规则,轻松实现灰度发布,同机房优先等功能。
6、可视化的服务治理与运维:提供丰富服务治理、运维工具,随时查询服务元数据、服务健康状态及调用统计,实时下发路由策略、调整配置参数。
Dubbo加载机制
Dubbo扩展点机制
Dubbo服务暴露/消费原理
Dubbo远程调用
Dubbo集群
Dubbo过滤器
这篇关于微服务-Dubbo原理探险的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!