首页 > 其他分享 >RPC

RPC

时间:2024-11-26 10:13:15浏览次数:2  
标签:调用 stub RPC 消息 本地 远程

1 RPC是什么
RPC,Remote Procedure Call,远程过程调用。 过程 就是业务处理、计算任务,也就是程序,像调用本地方法一样调用远程方法。
RPC的概念与技术早在1981年由Nelson提出。1984年,Birrell和Nelson把其用于支持异构型分布式系统间的通讯。Birrell的RPC 模型引入存根进程( stub) 作为远程的本地代理,调用RPC运行时库来传输网络中的调用。 Stub和RPC runtime屏蔽了网络调用所涉及的许多细节,特别是,参数的编码/译码及网络通讯是由stub和RPC runtime完成的,因此这一模式被各类RPC所采用。
这到底是如何能做到本地方法调用时转换成远程呢? RPC采用Client-Server结构,通过request-response消息模式实现。
RPC VS RMI RMI,remote method invocation,远程方法调用是OOP领域中RPC的一种具体实现。 webservice、restfull接口调用是RPC吗? 都是RPC,仅消息的组织方式及消息协议不同。
远程过程调用较本地调用区别:
速度相对慢可靠性减弱
RPC原理
1、客户端处理过程中调用Client stub (就像调用本地方法一样),传递参数
2、Client stub将参数编组为消息,然后通过系统调用向服务端发送消息
3、客户端本地操作系统将消息从客户端机器发送到服务端机器
4、服务端操作系统将接收到的数据包传递给Server stub
5、Server stub 解组消息为参数
6、Sever stub再调用服务端的过程,过程执行结果以反方向的相同步骤响应给客户端
核心是代理机制:
1、本地代理存根Stub,通过动态代理或 AOP 拦截请求
2、本地序列化反序列化
3、网络通信
4、远程序列化反序列化
5、远程服务存根Skeleton
6、调用实际业务服务
7、原路返回服务结果
8、返回给本地调用方

3 RPC协议
RPC调用过程中需要将参数编组为消息进行发送,接收方需要解组消息为参数,过程处理结果同样需要经编组、解组。
消息由哪些部分构成及消息的表示形式就构成了消息协议。 RPC调用过程中采用的消息协议称为RPC协议。
RPC协议规定请求、响应消息的格式在TCP (网络传输控制协议)上可选用或自定义消息协议来完成RPC消息交互
我们可以选用通用的标准协议(如: http、 https) ,也可根据自身的需要定义自己的消息协议!
4 RPC相关术语
Client、 Server、 calls、 replies、service、programs、procedures、version、marshalling(编组)、unmarshalling(解组)一个网络服务由一个或多个远程程序集构成一个远程程序实现一个或多个远程过程过程、过程的参数、结果在程序协议说明书中定义说明为兼容程序协议变更、一个服务端可能支持多个版本的远程程序

标签:调用,stub,RPC,消息,本地,远程
From: https://www.cnblogs.com/oldking1002/p/18569497

相关文章

  • 在 ASP.NET Core 中创建 gRPC 客户端和服务器
    前言gRPC是一种高性能、开源的远程过程调用(RPC)框架,它基于ProtocolBuffers(protobuf)定义服务,并使用HTTP/2协议进行通信。新建项目新建解决方案GrpcDemo新建webapi项目GrpcServer作为grpc服务端项目添加包<PackageReferenceInclude="Grpc.AspNetCore"Version="2.67.......
  • 聊聊git push到远程服务器出现RPC failed问题
    前言最近小组成员跟我说,他git提交不了代码。我问了下原因,他说他代码一提交就会报代码语言:txt复制error:RPCfailed;HTTP413curl22TherequestedURLreturnederror:413fatal:theremoteendhungupunexpectedlyfatal:theremoteendhungupunexpected......
  • 【gRPC】2—gRPC与PB&桩代码生成与扩展
    gRPC与PB&桩代码生成与扩展⭐⭐⭐⭐⭐⭐Github主页......
  • rpyc python rpc 框架
    rpyc属于一个老牌项目了,支持rpc模式的处理,同时支持面向服务的开发模式,包含了一些安全控制,支持服务注册,服务发现包含的特性透明,可以使用类似本地模式的方法访问对称,client以及server都可以支持调用支持同步以及异步操作平台无关低开销安全,支持基于tls,以及ssh的访问模......
  • 1024个线程居然不够用?RPC 线程池被打满!
    打开公司群,就看见群里有人讨论:线上环境出现大量RPC请求报错,异常原因:被线程池拒绝。虽然异常量很大,但是异常服务非核心服务,属于系统旁路,服务于数据核对任务,即使有大量异常,也没有实际的影响。原来有人在线上刷数据,产生了大量binlog,数据核对任务的请求量大幅上涨,导致线程池被打满。第......
  • ubuntu编译grpc & protobuf
    参考:Ubuntu系统中本地编译并安装grpc的C++版本及测试-知乎(zhihu.com)安装依赖:#这些可能都已经安装了sudoapt-getinstallpkg-configautoconfautomakelibtoolmakeg++unzip#下面的可能没安装sudoapt-getinstalllibgflags-devlibgtest-devsudoapt-getins......
  • 高效使用 gRPC 的配置技巧:深入解析 SocketsHttpHandler 设置
    在.NET中,gRPC是一个强大的远程过程调用(RPC)框架,能够高效地处理客户端和服务器之间的通信。为了最大化gRPC的性能,了解和优化SocketsHttpHandler的配置是关键。本文将介绍gRPC的使用技巧,并详细解释SocketsHttpHandler的重要配置项,并以表格的形式总结这些设置,以帮助开发者......
  • RPC接口返回值之争:基本类型 vs 包装类
    RPC接口返回值之争:基本类型vs包装类在分布式系统中,远程过程调用(RPC)是实现服务间通信的常见方式。当我们设计RPC接口时,一个常见的问题是:返回值应该使用基本类型还是包装类?这个问题看似简单,实则涉及到性能、可读性、错误处理等多个方面。今天,我们就来深入探讨这个话题,帮助......
  • Grpc之metadata
    hello.protosyntax="proto3";packagepb;optiongo_package="./pb";serviceGreeter{rpcSayHello(HelloRequest)returns(HelloReply){}}messageHelloRequest{stringname=1;}messageHelloReply{stringmessage=1;}pro......
  • Java服务端开发中的请求优化:从HTTP/1.1到HTTP/2与gRPC的升级
    Java服务端开发中的请求优化:从HTTP/1.1到HTTP/2与gRPC的升级大家好,我是微赚淘客返利系统3.0的小编,是个冬天不穿秋裤,天冷也要风度的程序猿!在现代Java服务端开发中,提升请求性能是至关重要的。随着HTTP/2和gRPC的引入,优化请求性能变得更加有针对性和高效。本文将探讨如何从HTTP/1.1......