<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

為什么有了HTTP,還需要RPC協議?

億佰特物聯網應用專家 ? 2023-08-14 10:05 ? 次閱讀

為什么有了HTTP,還需要RPC協議呢?在進行說明之前,首先我們需要了解什么是HTTP協議,什么是RPC協議。

0ea2595c-3a47-11ee-bbcf-dac502259ad0.png

什么是HTTP協議?

HTTP是一種廣泛使用的網絡傳輸協議,它定義了客戶端(如瀏覽器, 手機用戶APP等)和服務器(網站等提供服務的,服務端)之間的通信格式和通信方法,它是基于請求—響應這樣一種通信模型,即服務端根據請求返回一個響應,在請求和響應中,都包含了兩端(客戶端和服務端)之間進行交互的一些信息,如方法、頭部、正文等。

0eb13288-3a47-11ee-bbcf-dac502259ad0.png

圖1 HTTP交互基本流程圖


HTTP具有很多優點,它支持多種數據格式和編碼方式,可以實現跨平臺和跨語言的通信,通信簡單、靈活、易于擴展。但是同時它也有一些缺點:

(1)HTTP是無狀態的,每次請求都需要重新建立連接,這會增加網絡開銷和延遲。

(2)數據傳輸是基于文本的,這會導致數據量較大,解析效率較低。

(3)安全性較差,因此容易受到中間人攻擊、重放攻擊等。

(4)語義較弱,HTTP只能表達基本的增刪改查操作,不能滿足復雜的業務邏輯。

0ec55308-3a47-11ee-bbcf-dac502259ad0.png

什么是RPC協議?


RPC即Remote Procedure Call(遠程程序調用),它是一種遠程過程調用協議,它允許客戶端像調用本地函數一樣調用遠程服務器上的函數。

0ed30ad4-3a47-11ee-bbcf-dac502259ad0.png

圖2 RPC協議交互流程

RPC的優點是高效、強大、易于使用,但是它也有一些缺點,比如:

(1)與HTTP相反,RPC是有狀態的,需要維護客戶端和服務器之間的連接狀態,這會增加系統的復雜度和資源消耗。

(2)RPC的數據傳輸是基于二進制的,這會導致數據不易閱讀和調試。

(3)RPC的兼容性較差,不同的RPC框架之間可能存在協議和接口的不一致性。

(4)RPC的可擴展性較差,難以支持動態服務發現和負載均衡等功能。

0efebf6c-3a47-11ee-bbcf-dac502259ad0.png

二者的選擇使用


基于TCP建立的HTTP和各類RPC協議,只是定義了不同消息格式的應用層協議。HTTP協議是超文本傳輸協議,而RPC本身并不是一個具體的協議,而是一種調用方式。

0f1db37c-3a47-11ee-bbcf-dac502259ad0.png

雖然HTTP現在叫超文本協議,支持音頻視頻,但HTTP設計初主要是用做展示網頁文本,所以它傳輸的內容以字符串為主,內容存在非常多的冗余。而RPC協議定制化程度更高,可以采用體積更小的protobuf或其他序列化協議去保存結構體數據,同時也不需要像HTTP那樣考慮各種瀏覽器行為,性能更好。因此在公司內部微服務中拋棄HTTP,轉而使用RPC協議。雖然后來HTTP得到了很大的改進,但由于很多公司內部已經用了多年的RPC協議,基于歷史原因,一般沒有選擇更換成HTTP。

在實際運用中,不論是HTTP還是RPC,它們都有各自的優缺點,沒有絕對的好壞之分。針對不同的使用場景選擇合適的協議。比如:

(1)在微服務架構中,服務之間需要頻繁地進行內部調用,RPC可以提供更高的性能和可靠性。

(2)在分布式計算中,需要將大量的計算任務分發到不同的節點上執行,RPC可以實現更靈活的負載均衡和容錯機制。

(3)而在實時通信中,需要實現低延遲和高并發的數據交換,RPC可以支持多種傳輸協議和通信模式。

而假如你需要實現跨平臺和跨語言的通信,或者需要支持多種數據格式和編碼方式,或者需要利用現有的HTTP基礎設施和工具,可以選擇HTTP協議。

當然這樣不是絕對固定的組合,也可以結合兩個協議來實現更好的網絡,例如:

(1)我們可以在HTTP協議上封裝RPC協議,使得RPC請求可以通過HTTP代理或者網關來轉發和處理。

(2)可以在RPC協議上使用HTTP協議作為傳輸層,使得RPC請求可以利用HTTP的特性來實現緩存、壓縮、加密等功能。

所以總的來說,RPC的出現是為了應對HTTP協議滿足不了的對性能有所要求的網絡場景。它們并不是互斥的,而是可以根據不同的場景和需求進行選擇和組合的。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 通信
    +關注

    關注

    18

    文章

    5739

    瀏覽量

    134690
  • 協議
    +關注

    關注

    2

    文章

    572

    瀏覽量

    38954
  • 網絡
    +關注

    關注

    14

    文章

    7280

    瀏覽量

    87713
  • HTTP
    +關注

    關注

    0

    文章

    467

    瀏覽量

    30403
  • RPC
    RPC
    +關注

    關注

    0

    文章

    102

    瀏覽量

    11445
收藏 人收藏

    評論

    相關推薦

    為何在HTTP協議之外,我們還需要RPC協議?

    字節流可以理解為一個雙向的通道里流淌的數據,這個數據其實就是我們常說的二進制數據,簡單來說就是一大堆 01 串。純裸TCP收發的這些 01 串之間是沒有任何邊界的,你根本不知道到哪個地方才算一條完整消息。
    發表于 04-12 14:29 ?379次閱讀
    為何在<b class='flag-5'>HTTP</b><b class='flag-5'>協議</b>之外,我們<b class='flag-5'>還需要</b><b class='flag-5'>RPC</b><b class='flag-5'>協議</b>?

    請問risc-v中斷還需要軟件保存上下文和恢復嗎?

    risc-v中斷還需要軟件保存上下文和恢復嗎?
    發表于 02-26 07:40

    RT-Thread Studio中的RT-Thread Setting中已經軟件包管理和組件服務管理了,那還需要env工具嗎?

    RT-Thread Studio中的RT-Thread Setting中已經軟件包管理和組件服務管理了,那還需要env工具嗎,如果也使用env工具那不是和RT-Thread Setting中的管理沖突?
    發表于 02-23 07:36

    #2024,立Flag了嘛? #學習spinal HDL還需要學習對應的Scala語言

    學習spinal HDL還需要學習對應的Scala語言,但是spinal HDL直接貼近硬件編程,不知道對于學習spinal HDL什么好的建議?
    發表于 01-21 11:11

    aducm410微處理器還需要接外部晶振和復位電路嗎?

    aducm410微處理器還需要接外部晶振和復位電路嗎?
    發表于 01-11 07:23

    退出空載條件后,APNOLOAD和VARNOLOAD是否還需要清零?

    空載條件后,APNOLOAD和VARNOLOAD是否還需要清零,還是說只是上電進行一次清零。 謝謝。
    發表于 12-26 07:14

    數模轉換芯片AD7991配置完斷電后,還需要再次配置嗎?

    這個芯片在使用時,一些配置寄存器,用于配置芯片的工作方式。這個寄存器,配置完斷電后,還需要再次配置嗎? 這個芯片兩個型號—0和—1,配置時,地址不一樣。在芯片上沒看有標識,怎么判斷是哪個型號的?
    發表于 12-22 08:06

    STM8L在待機模式還需要給獨立看門狗喂狗嗎?

    STM8L在待機模式還需要給獨立看門狗喂狗嗎
    發表于 10-15 12:58

    用熱敏電阻測溫時候還需要放大電路嗎?

    用單片機ADC采樣這個熱敏電阻的溫度還需要放大電路嗎
    發表于 10-13 07:44

    使用變壓器變壓的電源還需要濾波器嗎

    使用變壓器變壓的電源還需要濾波器嗎
    的頭像 發表于 08-31 14:03 ?655次閱讀
    使用變壓器變壓的電源<b class='flag-5'>還需要</b>濾波器嗎

    什么是HTTP協議?什么是RPC協議?二者如何選擇使用?

    為什么有了HTTP,還需要RPC協議呢?在進行說明之前,首先我們需要了解什么是HTTP
    的頭像 發表于 08-11 09:25 ?1676次閱讀
    什么是<b class='flag-5'>HTTP</b><b class='flag-5'>協議</b>?什么是<b class='flag-5'>RPC</b><b class='flag-5'>協議</b>?二者如何選擇使用?

    什么是HTTP協議?HTTP協議的基本特點和發展歷程

    上期文章小編給大家介紹了一些關于MQTT協議的基礎知識,今天我們來了解另一個應用層協議——HTTP協議。
    發表于 08-04 09:52 ?661次閱讀
    什么是<b class='flag-5'>HTTP</b><b class='flag-5'>協議</b>?<b class='flag-5'>HTTP</b><b class='flag-5'>協議</b>的基本特點和發展歷程

    RPC接口和HTTP接口的區別與聯系

    ? HTTP服務 RPC接口和HTTP接口的區別與聯系 參考文獻 ? HTTP接口和RPC接口都是生產上常用的接口,顧名思義,
    的頭像 發表于 06-17 14:54 ?1262次閱讀
    <b class='flag-5'>RPC</b>接口和<b class='flag-5'>HTTP</b>接口的區別與聯系

    基于Client/Server架構的HTTP接口和RPC接口

    HTTP接口和RPC接口都是生產上常用的接口,顧名思義,HTTP接口使用基于HTTP協議的URL傳參調用,而
    發表于 06-13 09:18 ?480次閱讀
    基于Client/Server架構的<b class='flag-5'>HTTP</b>接口和<b class='flag-5'>RPC</b>接口

    RPC接口與HTTP接口哪一個更好?

    HTTP接口和RPC接口都是生產上常用的接口,顧名思義,HTTP接口使用基于HTTP協議的URL傳參調用,而
    發表于 06-13 09:18 ?750次閱讀
    <b class='flag-5'>RPC</b>接口與<b class='flag-5'>HTTP</b>接口哪一個更好?
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>