Dubbo概念与作用
一、介绍
-
Dubbo是一款高性能、轻量级的Java RPC框架,它的目标是提供高性能和透明化的RPC远程服务调用方案,使得应用之间可以通过RPC协议相互调用,从而降低系统之间的耦合度,提高应用的可扩展性和可维护性。
-
Dubbo支持多种协议(Dubbo、HTTP、REST、Hessian、Thrift)和多种注册中心(Zookeeper、Redis、Multicast、Simple等),支持多种负载均衡(Random、Round Robin、Least Active等),可以方便地实现服务注册、负载均衡、容错、服务降级、动态路由等功能。
二、流程
Dubbo的架构模型主要包括三个部分:服务提供者、注册中心和服务消费者。服务提供者将服务注册到注册中心,服务消费者从注册中心中获取服务提供者的信息并调用服务。
Dubbo的核心概念包括:
-
服务提供者:提供服务的应用程序,将服务注册到注册中心并等待消费者调用。
-
服务消费者:消费服务的应用程序,从注册中心获取服务提供者的信息并调用服务。
-
注册中心:服务提供者将服务注册到注册中心,服务消费者从注册中心获取服务提供者的信息,注册中心可以是Zookeeper、Redis等。
-
服务协议:Dubbo支持多种服务协议,包括Dubbo协议、HTTP协议、REST协议、Hessian协议、Thrift协议等。
-
负载均衡:当一个服务有多个提供者时,Dubbo提供了多种负载均衡策略,包括随机、轮询、最少活跃调用数等。
-
服务容错:Dubbo提供了多种容错机制,包括失败自动切换、失败自动恢复、快速失败等。
-
服务降级:当系统出现异常或者过载时,Dubbo提供了服务降级机制,可以根据业务需求选择降级处理方式。
总之,Dubbo是一款功能强大、易于使用、高性能的RPC框架,能够帮助企业快速构建分布式应用系统,提高应用的可扩展性和可维护性。
本文来自博客园,作者:手可敲星辰脚驾七彩云,转载请注明原文链接:https://www.cnblogs.com/arek/p/17248570.html,谢谢!