rpc原理與應用

  • IPC和RPC?

RPC

RPCRemote Procedure Call),又叫做遠程過程調用。它本身并不是一個具體的協議,而是一種調用方式

gRPC 是 Google 最近公布的開源軟件,基于最新的 HTTP2.0 協議,并支持常見的眾多編程語言。

HTTP2.0 是基于二進制的 HTTP 協議升級版本,目前各大瀏覽器都在快馬加鞭的加以支持。

這個 RPC 框架是基于 HTTP 協議實現的,底層使用到了 Netty 框架的支持。

Dubbo 是阿里集團開源的一個極為出名的 RPC 框架,在很多互聯網公司和企業應用中廣泛使用。協議和序列化框架都可以插拔是及其鮮明的特色。

同樣的遠程接口是基于 Java Interface,并且依托于 Spring 框架方便開發。可以方便的打包成單一文件,獨立進程運行,和現在的微服務概念一致。

Thrift 是 Facebook 的一個開源項目,主要是一個跨語言的服務開發框架。它有一個代碼生成器來對它所定義的 IDL 定義文件自動生成服務代碼框架。

用戶只要在其之前進行二次開發就行,對于底層的 RPC 通訊等都是透明的。不過這個對于用戶來說的話需要學習特定領域語言這個特性,還是有一定成本的。

什么是RPC

RPC【Remote Procedure Call】是指遠程過程調用,是一種進程間通信方式,他是一種技術的思想,而不是規范。它允許程序調用另一個地址空間(通常是共享網絡的另一臺機器上)的過程或函數,而不用程序員顯式編碼這個遠程調用的細節。即程序員無論是調用本地的還是遠程的函數,本質上編寫的調用代碼基本相同。

也就是說兩臺服務器A,B,一個應用部署在A服務器上,想要調用B服務器上應用提供的函數/方法,由于不在一個內存空間,不能直接調用,需要通過網絡來表達調用的語義和傳達調用的數據。為什么要用RPC呢?就是無法在一個進程內,甚至一個計算機內通過本地調用的方式完成的需求,比如不同的系統間的通訊,甚至不同的組織間的通訊,由于計算能力需要橫向擴展,需要在多臺機器組成的集群上部署應用。RPC就是要像調用本地的函數一樣去調遠程函數;

推薦閱讀文章:https://www.jianshu.com/p/2accc2840a1b

RPC基本原理

圖片

stub可以理解為存根

  • **客戶端存根,**存放服務端的地址消息,再將客戶端的請求參數打包成網絡消息,然后通過網絡遠程發送給服務方。
  • 服務端存根,接收客戶端發送過來的消息,將消息解包,并調用本地的方法。

一般包括客戶端、服務器端、服務注冊中心

**◎客戶端存根:**用于存放服務器端的地址信息,將客戶端的請求參數等信息打包成網絡消息,再通過網絡傳輸發送給服務器端。

**◎服務器端存根:**接收客戶端發送過來的請求消息并解包,然后調用本地服務處理。

存根之間通過網絡傳輸

同步調用和異步調用

這個過程有點類似于 Java 中的 Callable 和 Runnable 接口,我們進行異步執行的時候,如果需要知道執行的結果,就可以使用 Callable 接口,并且可以通過 Future 類獲取到異步執行的結果信息。并提前寫上對結果的操作邏輯。

如果不關心執行的結果,直接使用 Runnable 接口就可以了,因為它不返回結果,當然啦,Callable 也是可以的,我們不去獲取 Future 就可以了。

步驟解析:

圖片

RPC兩個核心模塊:通訊,序列化。

RPC主要基于TCP/IP

IDL:接口描述語言

調用方法=方法名+參數+返回值

RPC 框架的好處就顯示出來了,首先就是長鏈接,不必每次通信都要像 HTTP 一樣去 3 次握手什么的,減少了網絡開銷。

其次就是 RPC 框架一般都有注冊中心,有豐富的監控管理;發布、下線接口、動態擴展等,對調用方來說是無感知、統一化的操作。

gRPC

gRPC 是 Google 最近公布的開源軟件,基于最新的 HTTP2.0 協議,并支持常見的眾多編程語言。底層使用到了 Netty 框架的支持。

服務端:

監聽端口,注冊服務,啟動服務器

客戶端:

調用函數,傳參數,接收返回值

客戶端只有接口,用動態代理的方式實例化接口,在invoke方法中獲取方法名等信息發給服務端

proto文件(IDL)

框架:

自定義RPC協議

header+body

RPC IO 優化

任何服務都是類似的,大量請求過來時,得用線程池、異步、協程等各種手段優化,提高并發,從而提高吞吐,減小延遲。

有的 RPC 框架能解決這些問題,比如有些 RPC 框架內置協程模型,支持 M 比 N 模型、協程竊取等等。如果 RPC 框架不管,就需要用額外的線程池庫、異步庫(promise、future)、協程庫來手動控制請求的執行流并發執行。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/210587.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/210587.shtml
英文地址,請注明出處:http://en.pswp.cn/news/210587.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【SQLite】SQLite3約束總結

前面學習了SQLite數據庫的常見使用方法,其中包含許多約束,常見的如NOT NULL、DEFAULT、UNIQUE、PRIMARY KEY(主鍵)、CHECK等 本篇文章主要介紹這些約束在SQLite中的使用 目錄 什么是約束NOT NULL 約束DEFAULT約束UNIQUE約束PRIMA…

【設計模式-3.2】結構型——適配器模式

說明:本文介紹設計模式中結構型設計模式中的,適配器模式; 插頭轉換器 適配器模式屬于結構型設計模式,設計思想體現在結構上的。以插頭轉換器為例,當你需要給手機充電,但是眼前只有一個三孔插座&#xff0…

Java基本類型的高級使用方法詳解

引言 Java中的基本數據類型(primitive types)是構建程序的基礎,包括整型、浮點型、字符型、布爾型等。除了直接使用這些基本類型外,Java還提供了一些高級的使用方法,使得我們能夠更靈活地處理基本類型數據。本文將深入…

二叉樹結點個數、葉子結點個數、樹的高度、第k層結點個數的計算(C語言)

目錄 前言 分治算法 模擬二叉樹代碼 結點個數計算 錯誤方法 不便利方法 基于分治思想的方法 葉子結點個數 樹的高度 第k層結點的個數 前言 在鏈式二叉樹的前序、中序、后續遍歷中我們模擬了一棵二叉樹,并實現了它的前、中、后序遍歷,現在我們來…

UE4 .ini文件使用

在需要給配置文件的類中加上config標簽,當然變量也要加 在項目的Config下,新建一個Default類的UCLASS中config等于的名字,這里結合上面截圖就是DefaultTest 在下面寫入 [/Script/項目名/類名] 然后寫變量以及對應的值即可

【Angular 開發】Angular 信號的應用狀態管理

自我介紹 做一個簡單介紹,年近48 ,有20多年IT工作經歷,目前在一家500強做企業架構.因為工作需要,另外也因為興趣涉獵比較廣,為了自己學習建立了三個博客,分別是【全球IT瞭望】,【架構…

智能機器人在新材料方面遇到的挑戰

智能機器人在新材料方面面臨的挑戰包括但不限于以下幾點: 新材料的研發:機器人需要使用新材料來提高其性能和功能。然而,新材料的研發需要大量的時間和資金,同時還需要具備高超的技術和專業知識. 材料的可靠性:機器人…

GO面試題系列

1.GO有哪些關鍵字 2.GO有哪些數據類型 3.Go方法與函數的區別 在Go語言中,方法和函數是兩個不同的概念,盡管它們在某些方面有相似之處。下面是它們的主要區別: 定義位置: 函數: 函數是獨立聲明的,它們不…

python數據分析總結(pandas)

目錄 前言 df導入數據 df基本增刪改查 數據清洗 ?編輯 索引操作 數據統計 行列操作 ?編輯 df->types 數據格式化 ?編輯 日期數據處理 前言 此篇文章為個人python數據分析學習總結,總結內容大都為表格和結構圖方式,僅供參考。 df導入數…

Vue3使用vue-baidu-map-3x百度地圖

安裝vue-baidu-map-3x: // vue3 $ npm install vue-baidu-map-3x --save// vue2 $ npm install vue2-baidu-map --save 全局注冊/局部注冊: import { createApp } from vue import App from ./App.vue import BaiduMap from vue-baidu-map-3xconst app …

綜述 2017-Genome Biology:Alignment-free sequence comparison

Zielezinski, Andrzej, et al. "Alignment-free sequence comparison: benefits, applications, and tools." Genome biology 18 (2017): 1-17. https://genomebiology.biomedcentral.com/articles/10.1186/s13059-017-1319-7 被引次數:476應用問題&…

curl 18 HTTP/2 stream

cd /Users/haijunyan/Desktop/CustomKit/KeepThreadAlive/KeepThreadAlive //Podfile所在文件夾 git config --global https.postBuffer 10485760000 git config --global http.postBuffer 10485760000 pod install https://blog.csdn.net/weixin_41872403/article/details/86…

linux命令積累

1.查找指定目錄下第二層目錄,一年前的文件 find $dir -maxdepth 1 -type d -mtime 365 2./data/att/dir1軟連接到/data1/att/dir1 硬連接和軟連接的區別 硬連接 ln file1 file2 1.硬連接不能對目錄進行鏈接。 2.硬連接修改一個文件(不論修改哪方文件&…

top K問題(借你五分鐘)

目錄 前言 top K問題 模擬數據 建堆 驗證(簡單了解即可) 最終代碼 調試部分 前言 在大小堆的實現(C語言)中我們討論了堆的實際意義,在看了就會的堆排序(C語言)中我們完成了堆排序&#…

銀河麒麟本地軟件源配置方法

軟件源介紹 軟件源可以理解為軟件倉庫,當需要安裝軟件時則會根據源配置去相應的軟件源下載軟件包,此方法的優點是可以自動解決軟件包的依賴關系。常見的軟件源有光盤源、硬盤源、FTP源、HTTP源,本文檔主要介紹本地軟件源的配置方法&#xff…

功能強大的屏幕錄制和剪輯工具Camtasia Studio 2024 中文版

Camtasia Studio 2024 是一款功能強大的屏幕錄像工具,集視頻錄制、剪輯、編輯和播放于一體的多功能屏幕錄制軟件,Camtasia Studio 2024操作簡單,它能夠輕松為您將屏幕上的所有聲音、影音、鼠標移動的軌跡和麥克風聲音全部錄制下來&#xff0c…

分布式架構原理與實踐讀書筆記

分布式架構原理與實踐讀書筆記 IT 軟件架構的更迭:從單體架構,到集群架構,到現在的分布式和微服務架構。 分布式架構具有分布性、自治性、并行性、全局性等特點。 為了應對請求的高并發和業務的復雜性,需要對應用服務進行合理拆…

springboot(ssm暢游游戲銷售平臺 游戲電商系統Java系統

springboot(ssm暢游游戲銷售平臺 游戲電商系統Java系統 開發語言:Java 框架:ssm/springboot vue JDK版本:JDK1.8(或11) 服務器:tomcat 數據庫:mysql 5.7(或8.0) 數…

使用Jmeter做性能測試的注意點

一、性能測試注意點 1. 用jmeter測試時使用BeanShell腳本獲取隨機參數值,會導致請求時間過長,TPS過低。應改為使用csv讀取參數值,記錄的TPS會更加準確。 注:進行性能測試時,應注意會影響請求時間的操作,盡量…

[JVM 基礎 - Java 類加載機制]

這篇文章將帶你深入理解Java 類加載機制。 JVM 基礎 - Java 類加載機制 類的生命周期 類的加載: 查找并加載類的二進制數據連接 驗證: 確保被加載的類的正確性準備: 為類的靜態變量分配內存,并將其初始化為默認值解析: 把類中的符號引用轉換為直接引用初始化使用卸…