dubbo再回首

news2025/1/11 13:56:01

dubbo

服务框架, 远程通讯,集群容错,自动发现

spi:

      接口全限定名找到指定目录下对应的文件,获取具体的实现类然后加载

      增加缓存存储实例,对ioc api对支持

 流程:

 

   之前的博客实战总结: https://so.csdn.net/so/search?q=dubbo&t=blog&u=ma15732625261

Dubbo原理和机制详解(非常全面)-CSDN博客

注册中心:

    zk。redis。simple

支持的协议

dubbo:nio 复用单一长连接 线程池并发 

rmi:jdk自带 基于tcp 短连接

hessian:rpc框架基于http,大数据压缩,需要hessian.jar支持,需要序列化

webService:xml 远程调用,文本序列化 soap

thrif:跨语言 rpc  二进制 效率更高

RPC:远程方法调用方式

  rpcServer导出export远程接口,客户端RpcClient引入import远程接口

  提供接口代理实现实际委托rpcProxy封装调用信息转rpcInvoker执行

     客户端rpcInvoker通过rpcConnector维持服务端通道rpcChannel 使用rpcProtocol执行协议编码

     服务端rpcAcceptor接收客户端调用请求,使用rpcProtocol执行协议解码,rpcProcessor

通信

TCP:面向连接 可靠 基于字节流的传输层通信协议

 序列号按顺序发送数据 首部序列号+数据长度 =》下一步接受序号 应答返回

三次握手建立连接

浅谈TCP,一文带你搞懂TCP - 知乎 这篇其实就够了

四次挥手端口连接

TCP协议详解_tcp请求-CSDN博客

RMI:java中实现的rpc,j2ee

     远程对象实现rmi.Remote接口,实现UniCastRemoteObject类,能被访问到,将自身拷贝socket形式传输给客户端

netty

IO网络通信-CSDN博客 自己的博客 请笑纳

服务引入:代码流程

饿汉式

  调用referenceBean的afterPropertiesSet方法引入服务

    referenceBean实现factoryBean接口,任意服务interface进行自动注入或getBean获取,getObject函数服务引用过程

      本地引入走injvm协议,服务器缓存中取exporter

      直连远程引入服务,测试情况下 不需要启动注册中心,consumer配置写死地址 直连

      注册中心引入远程服务,consumer通过注册中心得知provider信息,服务引入

懒汉式:默认

   服务被注入到其他类启动引入流程,用到了再引入

获取注册中心实例,向注册中心注册自己,订阅providers configurators routers ,触发dubboInvoker生成,cluster封装多个服务调用者,返回一个invoker

配置构建一个map,利用map构建url,通过url协议利用自适应扩展机制调用相应的protocol.refer得到invoker,构建代理,封装invoker返回服务引用,consumer调用这个(提供者的)代理类

服务暴露:代码流程

url:

   protocol://username:password@host:port/path?key=value&key=value

protocol:各种协议 dubbo thrift http

path:接口名称。parameters:参数键值对

扩展:serviceBean实现了applicationListener,监听contextRefreshedEvent时间,ioc容器刷新完调用onApplicationEvent方法,暴露启动点,据配置url 利用dubbo spi 据url参数选择对应实现类

通过javassist动态封装服务实现类,同一暴露出invoker,封装exporter存储起来,等待消费者调用,url注册到注册中心,消费者获取服务提供者信息

 一个服务多个协议都需要暴露,多中协议分别向多注册中心暴露注册

调用过程

系统交互

rpc完成服务调用,多协议doubbo http rest

消费者调用服务时将 调用的服务接口信息 + 当前方法信息 + 执行方法入参信息 = invocation

不同协议将不同数据组织方式 / 传输方法 将对象传输给服务提供者

提供者接收对象,找到对应服务实现 反射执行方法 网络响应结果给消费者

    过程中服务容错 / 负载均衡 /filter机制 /动态路由 

负载均衡AbstractLoadBalance|doSelect

平衡加权轮询RoundRobinLoadBalance
private ConcurrentMap<String, ConcurrentMap<String, WeightedRoundRobin>> methodWeightMap = new ConcurrentHashMap<String, ConcurrentMap<String, WeightedRoundRobin>>();
加权随机RandomLoadBalance
for (int i = 1; i < length; i++) {
            int weight = getWeight(invokers.get(i), invocation);
            weights[i] = weight;//注意i下标
            // 计算出所有权重和,以便在进行随机时设定范围
            totalWeight += weight;
            if (sameWeight && weight != firstWeight) {
                sameWeight = false;
            }
        }
//针对各提供供者权重不一的情况,则找到第一个大于随机数的提供者即可
if (totalWeight > 0 && !sameWeight) {
            // If (not every invoker has the same weight & at least one invoker's weight>0), select randomly based on totalWeight.
            int offset = ThreadLocalRandom.current().nextInt(totalWeight);
            // Return a invoker based on the random value.
            for (int i = 0; i < length; i++) {
                offset -= weights[i];
                if (offset < 0) {
                    return invokers.get(i);
                }
            }
        }
一致性哈希ConsistentHashLoadBalance
private final ConcurrentMap<String, ConsistentHashSelector<?>> selectors = new ConcurrentHashMap<String, ConsistentHashSelector<?>>();

取第多少个参数,参与一致性hash算法 定位invoker

this.virtualInvokers = new TreeMap<Long, Invoker<T>>();

  treeMap虚拟节点,hashCode->invoker形式存储

最小活跃数LeastActiveLoadBalance
if (!sameWeight && totalWeight > 0) {
            // If (not every invoker has the same weight & at least one invoker's weight>0), select randomly based on 
            // totalWeight.
            // 如果权重不相同且权重大于0则按总权重数随机
            // 并确定随机值落在哪个片断上(第一个相减为负的值)
            int offsetWeight = ThreadLocalRandom.current().nextInt(totalWeight);
            // Return a invoker based on the random value.
            for (int i = 0; i < leastCount; i++) {
                int leastIndex = leastIndexes[i];
                offsetWeight -= weights[leastIndex];
                if (offsetWeight < 0) {
                    return invokers.get(leastIndex);
                }
            }
        }
自定义

实现loadBalance接口

添加文件src/main/resource/META-INF/dubbo/com.alibaba.dubbo.rpc.cluster.LoadBalance;

设置负载均衡策略

路由 --- 负载均衡 -- 集群容错

     Dubbo中先通过路由,从多个 Provider中按照路由规则,选出一个子集

     再据负载均衡从子集中选出一个 Provider 进行本次调用

     如调用失败,根集群容错策略,进行重试或定时重发或快速失败等

分层设计

https://cn.dubbo.apache.org/zh-cn/docsv2.7/dev/source/service-invoking-process/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1546306.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux之文件管理与重定向

文件的管理 最开始说到过, 一个进程是可以打开多个文件的并且可以对这些文件做出不同的操作, 也就是说加载到内存中的文件可能存在多个. 操作系统要不要管理这些打开的文件呢? 当我们在程序里面打开多个文件时, 操作系统肯定是得对这些文件进行管理的, 而管理的本质就是对数…

百度百科词条创建流程是怎样的?

百度百科词条&#xff0c;作为当今权威的知识分享平台之一&#xff0c;越来越多的个人和企业希望自己在百度百科上拥有独立的词条。如何创建一个高质量的百度百科词条呢&#xff1f;本文伯乐网络传媒将为您详细解析百度百科词条的创建流程及编辑技巧&#xff0c;并提供一些常见…

“数字化”持续走热,VR全景助力制造业上“云”

制造业要升级&#xff0c;数字化改造是重要途径。 早年间&#xff0c;由于对数字化的认识不足&#xff0c;一些企业明明有数字化改造需求&#xff0c;却不敢、不愿、不会上“云”。直到此次两会期间&#xff0c;2024年政府工作报告再次提出推动制造业数字化转型&#xff0c;越…

Learn OpenGL 25 法线贴图

为什么要引入法线贴图 我们的场景中已经充满了多边形物体&#xff0c;其中每个都可能由成百上千平坦的三角形组成。我们以向三角形上附加纹理的方式来增加额外细节&#xff0c;提升真实感&#xff0c;隐藏多边形几何体是由无数三角形组成的事实。纹理确有助益&#xff0c;然而…

SHA加密

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

软件设计师19--文件管理

软件设计师19--文件管理 考点1&#xff1a;文件相关概念例题&#xff1a; 考点2&#xff1a;树形目录结构&#xff08;绝对路径与相对路径&#xff09;例题&#xff1a; 考点3&#xff1a;位示图例题&#xff1a; 考点4&#xff1a;索引文件索引文件结构例题&#xff1a; 考点1…

【Java并发知识总结 | 第五篇】深入理解Synchronized底层原理(Monitor对象、Synchronized锁优化)

文章目录 5.深入理解Synchronized底层原理&#xff08;Monitor对象、Synchronized锁优化&#xff09;5.1Synchronized的特性5.1.1原子性5.1.2可见性5.1.3有序性5.1.4可重入性 5.2Synchronized的用法5.3Synchronized的两种同步方式4.3.1同步代码块5.3.2同步方法 5.4Synchronized…

第九届蓝桥杯大赛个人赛省赛(软件类)真题C 语言 A 组-分数

solution1 直观上的分数处理 #include <iostream> using namespace std; int main() {printf("1048575/524288");return 0; }#include<stdio.h> #include<math.h> typedef long long ll; struct fraction{ll up, down; }; ll gcd(ll a, ll b){if…

后端常见面经之MySQL

MySQL字段类型 数值类型 整型经常被用到&#xff0c;比如 tinyint、int、bigint 。默认是有符号的&#xff0c;若只需存储无符号值&#xff0c;可增加 unsigned 属性。 int(M)中的 M 代表最大显示宽度&#xff0c;并不是说 int(1) 就不能存储数值10了&#xff0c;不管设定了显…

openssl AF_ALG引擎使用

cmd AF_ALG是Linux提供的一种虚拟接口&#xff0c;用于访问内核中的加密算法。在Linux中&#xff0c;可以使用AF_ALG接口配合加密算法框架&#xff08;Crypto API&#xff09;来进行加密操作。 以下是一个使用AF_ALG和openssl进行加密操作的例子&#xff1a; # 加密 openssl…

SpringBoot—@ConditionalOnBean与@ConditionalOnClass

一、ConditionalOnBean概念 需求场景 比如下面一种场景&#xff0c;我在实例化People对象的时候&#xff0c;需要注入一个City对象。这个时候问题来了&#xff0c;如果city没有实例化&#xff0c;那么下面就会报空指针或者直接报错。 所以这里需求很简单&#xff0c;就是当前c…

服务运营|香港大学雷骁:收益管理中价格歧视的公平性

编者按&#xff1a; INFORMS George B. Dantzig Dissertation Award 用于表彰运筹学和管理科学领域中具有创新性和实用性的最佳毕业设计。香港大学助理教授雷骁题为“Revenue Management in Video Games and With Fairness” 是这一奖项2023年度的提名者之一。 这篇毕业设计重…

利用AI技术预测未被充分监测的流域中的极端洪水事件笔记

利用人工智能&#xff08;AI&#xff09;技术预测未被充分监测的流域&#xff08;ungauged watersheds&#xff09;中的极端洪水事件 文章目录 利用人工智能&#xff08;AI&#xff09;技术预测未被充分监测的流域&#xff08;ungauged watersheds&#xff09;中的极端洪水事件…

bsd猜想 Murmuration of Eliptic Curves(笔记)

BSD Alexey Pozdnyakov (University of Connecticut) YUTUBE视频&#xff0c; B站搬运地址新生代女数学家Nina Zubrilina得到椭圆曲线椋鸟群飞模式精确公式与证明 Arithmetic Geometry算术几何 希尔伯特第十问题 希尔伯特第十问题&#xff08;Hilbert’s Tenth Problem&#…

TransUNet论文笔记

论文&#xff1a;TransUNet&#xff1a;Transformers Make Strong Encoders for Medical Image Segmentation 目录 Abstract Introduction Related Works 各种研究试图将自注意机制集成到CNN中。 Transformer Method Transformer as Encoder 图像序列化 Patch Embed…

拼板注意事项和步骤

拼板注意事项和步骤 综述&#xff1a;本文讲述了AD软件中拼板的注意事项以及拼板的步骤。 1. 拼板注意事项 拼板时应注意定位孔、光学定位点、工艺边、间距和器件冲突等问题。 2. 拼板步骤 ①点击“放置”→“拼板阵列”→“panels”→“properties”&#xff0c;浏览需要…

晴问算法 动态规划(简单)

动态规划的递归写法和递推写法 斐波那契数列II 题目描述 给定正整数&#xfffd;&#xff0c;求斐波那契数列的第&#xfffd;项&#xfffd;(&#xfffd;)。 令&#xfffd;(&#xfffd;)表示斐波那契数列的第&#xfffd;项&#xff0c;它的定义是&#xff1a; 当&…

【MD】激光驱动原子动力学的全尺寸从头算模拟

Zeng Q, Chen B, Zhang S, et al. Full-scale ab initio simulations of laser-driven atomistic dynamics[J]. npj Computational Materials, 2023, 9(1): 213.核心研究内容&#xff1a; 本文研究了激光驱动的原子动力学的全尺度从头算模拟。研究的重点是探讨在极端条件下材料…

C语言结构体之位段

位段&#xff08;节约内存&#xff09;&#xff0c;和王者段位联想记忆 位段是为了节约内存的。刚好和结构体相反。 那么什么是位段呢&#xff1f;我们现引入情景&#xff1a;我么如果要记录一个人是男是女&#xff0c;用数字0 1表示。我们发现只要一个bit内存就可以完成我们想…

讯优随身WiFi可靠吗?讯优和格行随身WiFi哪个好?随身wifi推荐测评!随身WiFi哪个牌子比较好用?随身WiFi怎么选?随身WiFi推荐第一名!

随身WiFi挑花眼&#xff1f;不知道哪款好用&#xff1f;今天&#xff0c;我将为大家带来迅优与格行两大随身WiFi品牌的真实测评。 价格方面&#xff1a;迅优随身WiFi以价格优惠为卖点&#xff0c;吸引了众多消费者的目光。对于预算有限的用户来说&#xff0c;迅优确实提供了一个…