dubbo服务调用流程

Dubbo的整体架构中,有多个角色,分别是服务提供者,服务调用者以及服务注册中心。一次完整的服务调用过程其实要分为服务注册、服务发现和服务调用三个过程

1、服务注册

服务提供者在启动时,会向注册中心注册自己提供的服务,并将服务相关的信息(如服务名称、版本号、IP地址、端口号、协议、权重等)一并注册。Dubbo支持多种注册中心,包括ZooKeeper、Redis、Multicast、Simple等。一旦服务注册成功,服务提供者就可以等待服务调用请求的到来。

2、服务发现

服务调用者在启动时,需要向注册中心订阅自己所需的服务,注册中心会将服务提供者列表返回给服务调用者。当过程中,如果服务提供者列表发生变化,那么Dubbo会通知客户端进行变更

3、服务调用

服务调用者需要根据负载均衡策略选择一个服务提供者,之后,就可以发送服务调用请求了。Dubbo支持多种通信协议和序列化方式。Dubbo客户端将调用请求序列化成二进制数据,并使用网络协议发送给服务提供者,服务提供者将调用请求反序列化后,调用目标方法并将结果序列化成二进制数据返回给服务调用者。在整个调用过程中Dubbo会对服务调用进行监控,包括调用次数、调用时间、响应时间、异常次数、异常信息等,以便于服务提供者和服务调用者进行故障排查和性能调优

dubbo负载均衡机制

轮询策略、权重策略、最少活跃的策略、hash一致性策略

相关推荐
Warren985 天前
Java后端面试题(含Dubbo、MQ、分布式、并发、算法)
java·开发语言·分布式·学习·算法·mybatis·dubbo
不努力谁会可怜你?6 天前
Dubbo + zk 微服务
dubbo
Warren986 天前
Java Record 类 — 简化不可变对象的写法
java·开发语言·jvm·分布式·算法·mybatis·dubbo
z***8297 天前
vivo Pulsar 万亿级消息处理实践(2)-从0到1建设 Pulsar 指标监控链路
人工智能·dubbo
helloworld_工程师8 天前
Dubbo应用开发之基于xml的第一个Dubbo程序
dubbo
啥都不懂的小小白8 天前
Dubbo从入门到实战:分布式服务开发指南
分布式·dubbo
helloworld工程师10 天前
Dubbo应用开发之基于xml的第一个Dubbo程序
xml·dubbo·safari
阿里云云原生12 天前
一键上云不是梦!Apache Dubbo 发布微服务集群部署与全新控制台
dubbo