首页 > 编程语言 >Dubbo源码浅析(一)—RPC框架与Dubbo

Dubbo源码浅析(一)—RPC框架与Dubbo

时间:2023-09-28 10:35:01浏览次数:51  
标签:Dubbo 调用 服务 RPC 远程 Rpc 源码 浅析

一、什么是RPC

1.1 RPC概念

RPC,Remote Procedure Call 即远程过程调用,与之相对的是本地服务调用,即LPC(Local Procedure Call)。本地服务调用比较常用,像我们应用内部程序(注意此处是程序而不是方法,程序包含方法)互相调用即为本地过程调用,而远程过程调用是指在本地调取远程过程进行使用。

RPC框架就是为了帮助我们在本地调用远程过程时,就像调用本地过程一样方便。

1.2 RPC与Http的关系

用一句话来总结就是:

RPC是一种概念,http是一种协议,可以认为http是Rpc的一种实现,或者Rpc包含了http。为什么说包含而不是相等,是因为Rpc还有很多基于自定义的Tcp的协议,例如Dubbo等,而我们常说的rpc即指的除Http之外的基于tcp自定义的协议。

1.3 关于Rpc的思考

网上关于Rpc与Http的相关文章并不少,很多人在解释RPC概念时会提到其是执行远程的方法,然后直接得出rpc包含http的结论。其实如果按照此概念去思考的话,其实并不能得出Http是Rpc的一种实现。因为http调用的方式,从使用者的角度来说,并不是直接调用其方法,而是按照一定的方式,完善出了一条http请求,然后交由本地客户端进行数据传输。

而相对比的,如果用过相关Rpc框架,例如Dubbo,是可以像调用本地方法一样直接调用远程方法。而http的调用方式可以认为是一种服务调用,而不是一种方法。

感觉文章博主应该是有过rpc相关的使用经验,有点先入为主了。那么到底rpc与http的关系如何呢,我也思考了很久,后面发现应该从定义上入手,我们既然在讨论Rpc是什么,怎么能忽略最简单的定义呢。

Remote Procedure Call,其中"Procedure"按照谷歌翻译有以下几种解释:程序、过程、步骤,并不是方法(Method)。而程序是包含方法的,同时也包含服务。因此上文中才强调了是一种程序或过程,而不是方法。

1.4 Rpc框架

Rpc框架是为了帮助我们在本地服务调用远程服务时像调用本地服务一样简单,我们不需要关心其底层实现,只需要配置好相应的信息,rpc框架就会帮我们做这些事。例如在dubbo中,我们只需要配置好相应的注册中心与想要调用的方法,我们就可以按照本地调用的方式调用远程服务。

1.5 总结

按照我们上文的梳理过程,可以认为Rpc是一种概念,主要有两种实现,一种是以http方式的服务调用,另一种是以自定义Tcp协议实现的方法调用方式,例如dubbo协议,当然一般rpc框架也都支持http协议。当然,无论是那种方式,最终都是以Tcp/Udp的方式进行传输。

image-20221116163351469

二、Rpc框架

2.1 dubbo是什么

我们上文说到Rpc框架就是帮助我们在调用远程服务时像调用本地服务一样简单,dubbo就是由阿里巴巴开源的一块rpc框架。

例如,在我们想调用某个远程方法时,只需要配置好相关配置,然后直接调用即可,dubbo会帮助我们将处理中间的过程。

/*
省略相关配置
*/

//将配置注册到spring
@Resource
private QueryPinService queryPinService;

//直接使用远程方法,像调用本地服务一样简单
ueryPinService.getPinWithConfig(paramMap, null);




dubbo整体架构图如下:

图片

节点 说明
Provider 提供远程服务的服务提供方
Registry 注册中心
Consumer 需要调用远程服务的服务消费方
Container 服务运行的容器
Monitor 监控中心

作用流程大致如下:

首先服务提供者Provider 启动然后向注册中心注册自己所能提供的服务。

服务消费者Consumer 启动向注册中心订阅自己所需的服务。然后注册中心将提供者元信息通知给 Consumer, 之后 Consumer 因为已经从注册中心获取提供者的地址,因此可以通过负载均衡选择一个 Provider 直接调用

之后服务提供方元数据变更的话注册中心会把变更推送给服务消费者

服务提供者和消费者都会在内存中记录着调用的次数和时间,然后定时的发送统计数据到监控中心

2.2 dubbo和spring cloud的区别

首先两者都是当前主流的微服务框架,不过两者也存在很多差异:

  1. 初始定位不同:SpringCloud定位为微服务架构下的一站式解决方案,主要有网关、注册中心、配置中心、监控中心等;Dubbo 是 它的关注点主要在于服务的调用和治理,其中服务调用更时其核心。

  2. 生态环境不同:SpringCloud依托于Spring平台,具备更加完善的生态体系;而Dubbo一开始只是做RPC远程调用,生态相对匮乏,现在逐渐丰富起来。

  3. 调用方式:SpringCloud是采用Http协议做远程调用,接口一般是Rest风格,比较灵活;Dubbo是采用Dubbo协议,接口一般是Java的Service接口,格式固定。但调用时采用Netty的NIO方式,性能较好。

两者组件配置:

image-20221116173852813

很明显SpringCloud拥有比dubbo更完善的配置,支持的功能性也更强。

相比来说,SpringCloud像一台品牌机,内部所有配置都已经帮我们装配好了,我们只需要开箱即用即可。而dubbo则更像是组装机,需要我们自己选择配置,只提供了核心的计算能力,而显示器、电源等需要我们自己装配调试使用。

从使用者来说,新手小白更适合品牌机,傻瓜式一键操作,就能完成我们想要的效果。而dubbo更适合电脑高手,自己装配自己想要的组件,使用起来更顺手。

作者:京东科技 韩国凯

来源:京东云开发者社区 转载请注明来源

标签:Dubbo,调用,服务,RPC,远程,Rpc,源码,浅析
From: https://www.cnblogs.com/Jcloud/p/17735131.html

相关文章

  • Qemu源码分析(8)—Apple的学习笔记
    一,前言本节主要看stm32f4_discovery_board_init_callback函数,里面大概看明白了,主要是2个部分,一个是SDL的初始化,另外一个是mcu中各个模块中寄存器对象的属性添加及设置属性值。二,分析Object*object_new(constchar*typename)才会调用class_init和ti->instance_init看到了set"hse......
  • KBEngine服务端源码-分析
    目录后续会做更详细的更新classTask子类图示classTimerHandler子类图示Entity实体类--继承自(publicscript::ScriptObject)声明部分宏BASE_SCRIPT_HREADER宏SCRIPT_HREADER_BASE宏 ENTITY_HEADER实现部分宏ENTITY_METHOD_DECLARE_BEGIN宏ENTITY_CPP_IMPL宏SCRIPT_METHOD_DE......
  • Python桌面可视化+自动登录学校教务系统(含源码!!!)
    前言:通过Python爬虫与tkinter模块实现桌面快捷自动化登录教务系统效果展示:整体思路:创建主界面,在界面中手动输入用户名和密码,点击登录后自动打开浏览器,截取整个页面,裁剪出登录页面中的图片验证码并保存到本地,对验证码图片进行处理,识别出验证码。将用户名,密码,验证码一同自动输入到对......
  • Linux0.11代码浅析
    Linux0.11"pulloneselfupbyone'sbootstraps"......
  • YOLOV5源码解读-general.py、detect.py
    YOLOV5.4,可能与之前版本不一样,但大同小异general.py1#YOLOv5generalutils23importglob4importlogging5importmath6importos7importplatform8importrandom9importre10importsubprocess11importtime12frompathlibimpo......
  • WEBRTC回声消除-AECM算法源码解析之参数解析
    一概述 webrtc针对回声问题一共开源了3种回声消除算法,分别为aec,aecm,以及aec3,其中aec是最早期的版本,在后续的更新中aec3的出现代替了aec在webrtc中的地位,而aecm主要是针对计算能力较弱的移动端或是嵌入式设备而开发的,但同时也带来了它自己的劣势;本文主要介绍AECM算法的计......
  • DeepLabV3+网络模型与源码解读
    源码链接:链接:https://pan.baidu.com/s/1GkUM9WiGpzUHuFgBe1t2rA提取码:57zrorhttps://github.com/VainF/DeepLabV3Plus-Pytorch以上两个连接是一样的,只不过百度盘中的包含voc数据。 环境安装:先装pytorch&torchvision,再安装requirments.txt其他依赖 报错处理:#error:ra......
  • 手机直播源码,Android 简单的弹框
    手机直播源码,Android简单的弹框   privatestaticString[]items=newString[]{      "拍照",      "从相册中选择",  }; AlertDialog.Builderbuilder=newAlertDialog.Builder(MainActivity.this)        .setTitle(......
  • 基于web房屋租售管理系统-计算机毕业设计源码+LW文档
    摘 要当今,在这个信息化的时代,人们的生活越来越便利。因此如果运用java技术建设房屋租售管理系统系统使其与互联网有效的结合起来,实现房屋租售管理系统系统的网络化,为学校师生乃至社会提供更为全面、便捷的服务。根据本系统的研究现状和发展方向,首先系统从需求分析、结构设计、数......
  • UE4 源码剖析
    第一章对象系统1.1对象系统-类型系统构建(UClass,UFunction,UEnum,UStruct,FProperty)1.2对象系统-RPC函数1.3对象系统-Replicates属性1.4对象系统-Blueprint1.5对象系统-GC第2章网络模块2.1网络模块-跨平台的Socket2.x网络模块-CharacterMove......