返回列表 发新帖

如何在Dubbo中实现客户端对服务器的引用?

[复制链接]

6

主题

31

帖子

31

积分

新手上路

Rank: 1

积分
31
发表于 2024-8-25 21:38:43  | 显示全部楼层 | 阅读模式
Dubbo是一个高性能的Java分布式RPC框架,它允许客户端通过网络引用远程服务器上的对象和服务。通过简单的配置,开发者可以方便地实现服务调用,而无需关注底层的网络通信细节。
在分布式计算中,Dubbo作为一款高效能的Java RPC框架,被广泛应用于实现服务之间的通信,Dubbo客户端引用服务器的过程是整个服务调用链路中至关重要的一环,它涉及到服务发现、集群容错、负载均衡以及服务降级等关键功能,下面将详细探讨Dubbo客户端如何引用服务器,并从四个主要方面进行讨论:

zbhjqieqr3qlcv2.jpg

zbhjqieqr3qlcv2.jpg


(图片来源网络,侵删)
1、服务引用时机
懒汉式与饿汉式的区别:Dubbo支持两种服务引用时机,即懒汉式和饿汉式,懒汉式是指在实际服务被注入或引用时才创建服务,而饿汉式则在配置加载完成时就立即创建服务。
服务引用的具体时机:服务引用主要发生在两个时机,一是Spring容器调用ReferenceBean的afterPropertiesSet方法时,二是ReferenceBean对应的服务被注入到其他类中时。
2、服务引用流程
获取服务地址:首先从注册中心获取已注册的服务URL信息。
生成Invoker对象:利用指定的协议将服务URL信息转换为Invoker,这一步屏蔽了网络调用细节。
应用集群策略:通过集群策略和负载均衡技术处理Invoker集合,生成一个可供直接调用的Invoker。

zbhj5jml5ruyhzu.png

zbhj5jml5ruyhzu.png


(图片来源网络,侵删)
服务转换:使用ProxyFactory将Invoker转换成用户需要的接口,以便像调用本地服务一样调用远程服务。
3、配置检查收集
配置正确性确认:在进行服务引用之前,Dubbo会先进行检查,确保所有配置都是正确的。
收集配置信息:将配置文件中关于服务引用的相关配置信息收集起来,为后续步骤做准备。
4、代理对象生成
实现代理类:通过ProxyFactory将Invoker转化为实现了对应接口的代理对象,用户通过这个代理对象调用远程服务。
订阅服务:当客户端获取代理类的时候,同时也会订阅服务,以便接收服务端发出的通知。

zbhjsfwmlgwwgct.jpg

zbhjsfwmlgwwgct.jpg


(图片来源网络,侵删)
Dubbo客户端引用服务器是一个涉及配置检查、服务发现、网络调用封装及代理对象生成等多个环节的复杂过程,这一过程不仅隐藏了网络通信的复杂性,还提供了集群容错和负载均衡等高级特性,极大地简化了开发者对于远程服务的调用。
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表