前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >RPC协议了解

RPC协议了解

作者头像
全栈程序员站长
发布2022-08-31 15:13:24
2790
发布2022-08-31 15:13:24
举报

大家好,又见面了,我是你们的朋友全栈君。

1.RPC概述 RPC(Remote Procedure Call Protocol)远程过程调用协议。 通俗的描述是:客户端在不知道调用细节的情况下,调用存在于远程计算机上的某个过程或函数,就像调用本地应用程序中的一 样。 正确的描述是:一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。

2.RPC特点: 2.1)RPC是协议:协议意味着规范。目前典型的RPC实现包括Dubbo、Thrift、Herrty等。但这些实现往往都会附加其他重要功能 ,例如Dubbo还包括服务管理、访问权限管理等功能。 2.2)网络协议和网络IO模型对其透明:既然RPC的客户端认为自己是在调用本地对象。那么传输层使用的是TCP/ UDP还是http协议,又或者是一些其他的网络协议它就不需要关心了。既然网络协议对其透明,那么调用过程中,使用的是哪一种网络IO模型调用者也不需要关心。 2.3)信息格式对其透明:远程调用过程中,需要传递一些参数,并且会返回一个调用结果。至于这些参数会以某种信息格式传递 给网络上的另一台计算机,这个信息格式是怎样构成的,调用方是不需要关心的。 2.4)跨语言能力:对于调用方来说,不知道也无需知道远程的程序使用的是什么语言运行的,无论服务器方使用的是什么语言, 本次调用都应该成功,并且返回值也应该按照调用方程序语言所能理解的形式描述。

3.RPC原理 3.1)实现RPC的程序包括5个部分:User、User-stub、RPCRuntime、Server-stub、Server。 3.2)user:就是发起RPC调用的client,当user想发起一个远程调用时,它实际是通过本地调用user-stub。user-stub负责将 调用的接口、方法和参数通过约定的协议规范进行编码并通过本地的RPCRuntime实例传输到远程的实例。远程RPCRuntime实例收到请求后交给server-stub进行解码后发起本地端调用,调用结果再返回给user端。 3.3)stub:为屏蔽客户调用远程主机上的对象,必须提供某种方式来模拟本地对象,这种本地对象称为存根(stub),存根负责 接收本地方法调用,并将它们委派给各自具体实现对象。

在这里插入图片描述
在这里插入图片描述

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/144241.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年5月1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档