程序员2022年你不懂RPC远程过程调用,RPC框架的话真的要被淘汰了
ccwgpt 2024-09-17 12:50 31 浏览 0 评论
在微服务架构中,使用RPC(Remote Procedure Call)进行服务之间的交互是我们通常采用的一种集成方式,与REST方式的请求调用模式相比,RPC具有更强的契约规范(Schema),同时相比REST方式也有更好的性能优势。
RPC框架概述
RPC是一种进程间通信方式,可以像调用本地服务一样调用远程服务。RPC的核心并不在于使用什么协议,RPC的主要目标是让远程服务调用更简单、透明,让远程方法调用如本地调用一样方便,我们并不需要知道这个调用的方法所部署的网络位置。
RPC通信过程
RPC主要用到了动态代理模式。RPC框架负责屏蔽底层的传输方式(TCP或者UDP)、序列化方式(XML、JSON、二进制)和通信细节。开发人员在使用的时候只需要了解谁在什么位置提供了什么样的远程服务接口即可,并不需要关心底层通信细节和调用过程,如下图所示。
● 远程提供者需要以某种形式提供服务调用相关的信息,包括但不限于服务接口定义、数据结构、中间态的服务定义文件。
例如Facebook的Thrift的IDL文件,Web Service的WSDL文件,服务的调用者需要通过一定的途径获取远程服务调用相关的信息。
● 远程代理对象:远程代理对象是为一个对象在不同地址空间提供的局部代表,它可以将一个对象隐藏于不同地址空间。
● 通信:RPC框架与具体的协议无关。
● 序列化:毕竟是远程通信,需要将对象转化成二进制流进行传输。不同的RPC框架应用的场景不同,在序列化上也会采用不同的技术。
RPC和REST对比RPC和REST在请求模式上都属于点对点的请求/响应模式。REST是一种设计风格,它的很多思维方式与RPC是相互冲突的。RPC的思想是把本地函数映射到API,也就是说一个API对应的是一个函数方法(Function)。例如本地有一个getAllUsers方法,能通过某种约定的协议来远程调用这个getAllUsers方法,至于这个协议是Socket、HTTP还是其他协议并不重要,RPC中的主体是动作,强调互操作性。而REST则不然,它的URL链接主体是资源,REST强调远端的资源访问,而且REST大多数基于HTTP完成,规定了使用HTTP Method表达本次要做的动作,类型一般也不超过四五种。这些动作表达了对资源仅有的几种转化方式。
RPC最大的劣势是“紧耦合”,RPC客户端以多种方式与服务实现紧密耦合,它很难在不中断客户端的情况下更改服务实现。所以RPC的集成交互方式更偏向内部调用,而REST更偏向外部调用。Web服务应该算RPC的一个子集,理论上RPC能实现的功能用Web服务也能实现,甚至很多RPC框架选用HTTP作为传输层。
我们讨论RPC和Web的区别,主要关注两个因素:序列化协议和传输协议。序列化协议比如常见的XML,以及JSON和比较现代的ProtocolBuffers、Thrift。传输协议比如TCP、UDP,以及更高层的HTTP 1.1、HTTP 2.0。
一般我们用RPC而不是HTTP构建自己的服务,通常考虑下面的因素:
● 接口是否需要Schema约束。
● 是否需要更高效的传输协议(TCP、HTTP 2.0)。
● 是否对性能、数据包的大小非常敏感。
HTTP是基于文本的协议,头部需要提供多冗余(对于RPC服务而言)的协议头信息。HTTP中我们用得最多就是RESTful框架,而RESTful框架本质上基于弱Schema约束协议。对于RPC方式的调用来说,Thrift这种序列化协议的优势在于有非常严格的IDL(交互规范约束Schema)的存在,可以保证服务端接收的参数和Schema保持一致。
RPC与Web Service对比Web Service是在RPC的基础上发展而来的。它可以使用开放的XML来描述、发布、发现、协调和配置这些应用程序,它可以用于开发分布式交互操作的应用程序。而RPC使用C/S方式发送请求到服务器,等待服务器返回结果。
Web Service提供的服务是基于Web容器的,底层使用HTTP,类似于一个远程的服务提供者。比如天气预报服务,对各地客户端提供天气预报,是一种请求应答机制,是跨系统、跨平台的。
RPC与RMI的对比
RMI只用于Java中以客户端的存根对象(Stub)作为远程接口进行远程方法的调用。每个远程方法都具有方法签名。如果一个方法在服务器上执行,但是没有匹配的签名被添加到这个远程接口(Stub)上,那么这个新添加的方法就不能被RMI客户端所调用。
RPC是网络服务协议,与操作系统和语言无关,RPC通过网络服务协议向远程主机发送请求,请求包含一个参数集和一个文本值,通常形成“classname.methodname(参数集)”的形式。RPC远程主机会去搜索与之相匹配的类和方法,找到后就执行方法并把结果编码,再通过网络协议发回。
本文给大家讲解的内容是RPC远程过程调用,RPC框架概述
- 下篇文章给大家讲解的内容是RPC远程过程调用,主流RPC通信框架
- 觉得文章不错的朋友可以转发此文关注小编;
- 感谢大家的支持!
相关推荐
- MFC、Qt、WPF?该用哪个?(mfc和wpf区别)
-
MFC、Qt和WPF都是流行的框架和工具,用于开发图形用户界面(GUI)应用程序。选择哪个框架取决于你的具体需求和偏好。MFC(MicrosoftFoundationClass)是微软提供的框架,...
- 一款WPF开发的通讯调试神器(支持Modbus RTU、MQTT调试)
-
我们致力于探索、分享和推荐最新的实用技术栈、开源项目、框架和实用工具。每天都有新鲜的开源资讯等待你的发现!项目介绍Wu.CommTool是一个基于C#、WPF、Prism、MaterialDesign...
- 关于面试资深C#、WPF开发工程师的面试流程和问题
-
一、开场(2-3分钟)1.欢迎应聘者,简单介绍公司和面试流程。2.询问应聘者是否对公司或岗位有初步的问题。二、项目经验与技术应用(10-20分钟)1.让应聘者详细介绍几个他参与过的C#、...
- C# WPF MVVM模式Prism框架下事件发布与订阅
-
01—前言处理同模块不同窗体之间的通信和不同模块之间不同窗体的通信,Prism提供了一种事件机制,可以在应用程序中低耦合的模块之间进行通信,该机制基于事件聚合器服务,允许发布者和订阅者之间通过事件进行...
- WPF 机械类组件动画制作流程简述(wps上怎么画机械结构简图)
-
WPF机械类组件动画制作流程简述独立观察员2025年3月4日一、创建组件创建组件用户控件,将组件的各部分“零件”(图片)拼装在一起,形成组件的默认状态:二、给运动部分加上Rend...
- C#上位机WinForm和WPF选哪个?工控老油条的"血泪史"
-
作为一个从互联网卷进工控坑的"跨界难民",在这会摸鱼的时间咱就扯一下上位机开发选框架这档子破事。当年我抱着WPF的酷炫动画一头扎进车间,结果被产线老师傅一句"你这花里胡哨的玩意...
- 【一文扫盲】WPF、Winform、Electron有什么区别?
-
近年来,随着软件开发的不断发展,开发人员面临着选择适合他们项目的各种框架和工具的挑战。在桌面应用程序开发领域,WPF、Winform和Electron是三个备受关注的技术。本文将介绍这三者的区别,帮助...
- 一个开源、免费、强大且美观的WPF控件库
-
我们致力于探索、分享和推荐最新的实用技术栈、开源项目、框架和实用工具。每天都有新鲜的开源资讯等待你的发现!项目介绍HandyControl是一套基于WPF(WindowsPresentationF...
- WPF 根据系统主题自动切换浅色与深色模式
-
WPF根据系统主题自动切换浅色与深色模式控件名:Resources作者:WPFDevelopersOrg-驚鏵原文链接[1]:https://github.com/WPFDevelopers...
- WPF与WinForm的本质区别(wpf与maui)
-
在Windows应用程序开发中,WinForm和WPF是两种主要的技术框架。它们各自有不同的设计理念、渲染机制和开发模式。本文将详细探讨WPF与WinForm的本质区别,并通过示例进行说明。渲染机制W...
- Win10/Win11效率神器再进化:微软发布PowerToys 0.90.0版本
-
IT之家4月1日消息,微软今天(4月1日)更新PowerToys,在最新发布的0.90.0版本中,修复多个BUG之外,引入多项功能更新,为Windows10、Windows...
- 一款非常漂亮的WPF管理系统(wpf架构及特性)
-
我们致力于探索、分享和推荐最新的实用技术栈、开源项目、框架和实用工具。每天都有新鲜的开源资讯等待你的发现!WPFManager项目介绍该项目是一款WPF开发的管理系统,数据库采用的MSSqlserv...
- WPF 实现描点导航(wpf按钮的点击事件)
-
WPF实现描点导航控件名:NavScrollPanel作者:WPFDevelopersOrg-驚鏵原文链接[1]:https://github.com/WPFDevelopersOrg/WPF...
- 微软更新基于Win11的Validation OS 2504:增强 .NET与WPF
-
IT之家5月1日消息,科技媒体NeoWin今天(5月1日)发布博文,报道称微软公司更新基于Windows11的ValidationOS,增强支持.NET和WPF,并优...
- WPF的技术架构与优势(wpf的前景)
-
WindowsPresentationFoundation(WPF)是一个现代化的用户界面框架,专为构建Windows应用程序而设计。它通过分层的技术架构和丰富的功能集,提供了全面的应用程...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- MVC框架 (46)
- spring框架 (46)
- 框架图 (58)
- bootstrap框架 (43)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- jpa框架 (47)
- laravel框架 (46)
- express框架 (43)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (52)
- java框架spring (43)
- grpc框架 (55)
- orm框架有哪些 (43)
- ppt框架 (48)
- 内联框架 (52)
- winform框架 (46)
- gui框架 (44)
- cad怎么画框架 (58)
- ps怎么画框架 (47)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)
- oracle提交事务 (47)