RPC簡介

RPC 技术原理
       RPC ( Remote Procedure Call Protocol,远程过程调用协议 ): 客户端在不知道调用细节的情况下,调用存在于远程计算机上的某个对象,就像调用本地应用程序中的对象一样 。

1.RPC要点

RPC 是协议 : 既然是协议就只是一套规范规则,也就需要有人遵循这套规范来进行实现 。 目前典型的 RPC 实现包括 : dubbo (注意是小写的,不是大写的 DUBBO 服务治理框架〉 、 Apache Thrift、 GRPC 、 Hetty等 。

网络协议和网络I/O模型对其透明 : 既然 RPC 的客户端认为自己是在调用本地对象,那么传输层使用的是 TCP 还是 HTTP 协议, 又或者是一些其他的网络协议它就不需要关心了。

信息格式对其透明 : 这些调用与返回的参数会以某种信息格式传递给网络上的另外一台计算机,这个信息格式是怎样构成的,调用方就不需要关心了 ,

RPC 框架都应该有跨语言能力:当然,现实情况下由于一些 RPC 框架的特殊工作场景 ,也没有强行要求其提供跨语言能力,例如只工作在 Java 语言下的 RMI 就是这样一套 RPC 框架。

2.RPC要素

?  Client: RPC 协议的调用者。最理想的情况是 RPC 调用者在完全不知道有 RPC 框架存在的情况下发起对远程服务的调用。但实际情况来说 Client 或多或少都需要指定RPC框架的一些细节。
     ? Server : 在 RPC 规范中 , 这个 Server 并不是提供 RPC 服务器 IP、端口监昕的模块 。 而是远程服务上业务逻辑的具体实现(在 Java 中就体现为 RPC 服务接口的具体实现) 。其中的代码是最普通的和业务相关的代码,甚至其接口实现类本身都不知道将被某一个 RPC 远程客户端调用。
     ? Proxy: RPC 代理存在于客户端 , 因为要实现客户端对 RPC 框架“透明”调用,那么客户端就不可能自行去管理消息格式 , 不可能自己去管理网络传输协议,也不可能自己去判断调用过程是否有异常。这一切工作在客户端都是交给RPC框架中的“代理”层来处理的。
     ? Message Protocol : 一次完整的 RPC Client-Server 的交互肯定要携带某种两端都能识别的,共同约定的消息格式。 RPC 的消息管理层专门对网络传输所承载的信息进行编号和解码操作。目前流行的技术趋势是不同 的 RPC 实现,为了加强自身框架的效率都有一套(或者几套)私有 的 消息格式 。例如后文我们将讲解的 一套 RPC 框架 Apache Thrift , 就 拥 有私有 化的 消息 协 议。当然 Ap ache Thri位 还支持通用的消息格式,如JSON )。
     ? Transfer/Network Protocol : 传输协议层负责管理 RPC 框架所使用的网络协议、网络I/O模型 。 例如 Hessian 的传输协议基于 Http (应用层协议) : 再例如 Apache Thrift的传输协议基于 TCP (传输层协议)。传输层还需要统一 RPC 客户端和 RPC 服务端所使用的网络I/O模型 。
     ? Processor:存在于 RPC 服务端,由于服务器端某一个 RPC 接口的实现特性(它并不知道自己是一个将要被 RPC 提供给第三方系统调用的服务)。所以在 RPC 框架中应该有一种“负责执行 RPC 接口实现”的角色。它的职责包括管理RPC接口的注册、判断客户端的请求权限、控制接口实现类的执行在 内的各种工作 。
     ? IDL :虽然 IDL (接口定义语言)并不是 RPC 实现中所必须的。但是需要跨语言的RPC 框架一定会有 IDL 部分的存在。这是因为要找到一个各种语言能够理解的消息结构、接口定义的描述形式 。 如果你的 RPC 实现没有考虑跨语言性,那么 IDL 部分就不需要。例如 Java RMI 就是一种专门在 Java 语言间进行使用的特殊的 RPC 框架,它设计之初就没有要求要有跨语言执行特性,所以 Java RMI 没有相应的 IDL 。
     ? 不同的 RPC 实现都有一定设计差异。例如生成 Proxy 的方式不一样 、 IDL 描述语言的语法不一样、服务注册的管理方式不一样、运行服务实现的方式不一样 、 采用的消息格式封装不一样、采用的网络协议不一样,等等。


3.典型的 RPC 框架介绍

     1)Java RMI : Java RPC , Java Serializable, TCP,        java
     2)GRPC     : Google,    ProtoBuf,          HTTP/2,     众多语言
     3)Thrift   :FaceBook,  Thrift(私有二进制,LVQ,JSON),  TCP,        众多语言
     4)Hetty    :Netty/Hessian, 私有二进制,   HTTP,       众多语言
     5)WebService: XFire/CXF, XML,              HTTP,       众多语言

原文地址:https://www.cnblogs.com/gispathfinder/p/9033142.html

时间: 2024-10-10 01:57:51

RPC簡介的相关文章

2016_高煥堂_簡介

認識 高煥堂 老師(台北市) [email protected] [最近照片]    [簡介] 高焕堂先生 专精于VR文创素材IP商业模式.现任台湾VR/AR产业联盟主席.台湾工业研究院VR领域HTC Vive资深技术讲师.最近也兼任福州和南昌VR产业基地的VR技术教练.自从2014年开始担任台湾大宇信息(游戏产品:大富翁.仙剑奇侠传)公司董事,实际参与游戏素材IP的商业策略. 拥有41年码农经验.主修于美国Colorado州大学信息科学研究所.台湾淡江大学管理科学研究所.专精于Android终

SQL Server 的 Statistics 簡介

當你要清空「資料表(table)」,或倒入大量「資料(data;record)」,或公司「資料庫(database)」改用新版本要資料大搬家…等情形,不只是要重建「索引(index)」,還應要重建或更新「統計(statistics)」.「統計」的正確與否,直接牽動 SQL Server 的「效能(performance)」.沒有「統計」固然不好,「統計」若過時,會讓最佳化程式做出錯誤的決定則更糟. SQL Server 的查詢最佳化程式,會用索引的「統計」,來獲得它所需要的「資訊(informa

五金知識簡介

一.鋼板(包括帶鋼)的分類:1.按厚度分類:(1)薄板(2)中板(3)厚板(4)特厚板2.按生產方法分類:(1)熱軋鋼板(2)冷軋鋼板3.按表面特征分類:(1)鍍鋅板(熱鍍鋅板.電鍍鋅板)(2)鍍錫板(3)復合鋼板(4)彩色塗層鋼板4.按用途分類:(1)橋粱鋼板(2)鍋爐鋼板(3)造船鋼板(4)裝甲鋼板(5)汽車鋼板(6)屋面鋼板(7)結構鋼板(8)電工鋼板(硅鋼片)(9)彈簧鋼板(10)其他 冷軋板 因本公司使用的鋼板均為JIS標準,在這裡介紹公司用的日本牌號所代表的材質.SPCC---表示一

Makefile 語法簡介

有稍稍在 Linux 下碰過程式設計的開發者應該會知道,make 是用來將程式碼.函式庫.標頭檔及其它資源檔 build 成最終成果(即:最終的應用程式)的超強力輔助工具. 當然了,並不是非得動用到 make 才能 build 程式,或許有什麼程式設計魔人喜歡什麼都自己手動進行:但利用 make 及其參考檔(輸入檔案)Makefile將會讓整個編譯工作輕鬆許多.若您曾經打包過 Debian Package,那麼應該會發現 debuan/rule 這個檔案的語法和 Makefile 幾乎是一模一樣

ToolStrip和MenuStrip控件簡介及常用屬性(转)

ToolStrip和MenuStrip實際上是相同的控件,因為MenuStrip直接派生於ToolStrip.也就是說ToolStrip可以做的工作,MenuStrip也能完成. ToolStrip(工具欄)是ToolStripButton.ToolStripComboBox.ToolStripSplitButton.ToolStripLabel.ToolStripSeparator.ToolStripDropDownButton.ToolStripProgressBar 和 ToolStrip

第一章 Linux內核簡介

1. Linux是類Unix系統,但他不是Unix. 儘管Linux借鑑了Unix的許多設計並且實現了Unix的API(由Posix標準和其他Single Unix Specification定義的),但Linux沒有像其他Unix變種那樣直接使用Unix的源代碼. 2. Linux系統的基礎是內核.C庫.工具集和系統的基本工具,如登錄程序和Shell. 3. 操作系統是指在整個系統中負責完成最基本功能和系統管理的那些部分.這些部分應該包括內核.設備驅動程序.啓動引導程序.命令行Shell或者其

PCB成型製程介紹

PCB成型製程在電子構裝中所扮演的角色 下圖是電腦主機的內部組成 我們將以插在主機板上的一片 USB擴充卡來說明PCB成型製 程在電子構裝中所扮演的角色 PCB成型製程的子製程 USB擴充卡要插入主機板上的插槽進行電子訊號的聯結.為了降低板子 插入時的阻力,會在板子的邊緣做出一斜面(如圖所示),要做出這個斜邊, 就要靠斜邊製程. 斜邊製程 要在板邊做出斜邊,主要是以端銑刀對板子邊緣進行旋轉切削. 斜邊製程品質異常範例 斜邊深度大時,會使用二支Spindle作兩段式作業,但二支Spindle的角度

FMDB與SQLite 數據庫應用示範:打做一隻簡單的電影資料庫 App

原文:http://www.appcoda.com/fmdb-sqlite-database/ 作者:GABRIEL THEODOROPOULOS 譯者:kmyhy 通常在 App 中使用數據庫并處理數據都會是一個重要和嚴肅的話題.在幾個月前我寫了一篇關於如何利用 SwiftyDB 來管理 SQLite 數據庫的文章.今天,我又提起數據庫這個話題,只不過這次我會介紹另一個庫.你也許聽說過了,它就是FMDB. 這兩個庫的功能都是一樣的,都是用來與 SQLite 數據庫打交道并允許你高效地管理你的

[轉]Android Libraries 介紹 - Butter knife

原文地址 Butter Knife 簡介 Butter Knife - Field and method binding for Android views.助你簡化程式碼,方便閱讀. 使用方法 開發 andriod app 的時候,一定有寫過類似的 code: class ExampleActivity extends Activity { TextView title; TextView subtitle; TextView footer; @Override public void onC