一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

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

3天內(nèi)不再提示

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

kae1_cdebyte ? 來源:億佰特物聯(lián)網(wǎng)應(yīng)用專家 ? 2023-08-11 09:25 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

01什么是HTTP協(xié)議?

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

wKgZomTVjh6AY7K9AAAIzTOV66Q161.png

圖1 HTTP交互基本流程圖

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

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

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

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

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

02什么是RPC協(xié)議?

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

wKgaomTVjh6ABmIgAAEX_MmADKY665.png

圖2 RPC協(xié)議交互流程

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

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

(2)RPC的數(shù)據(jù)傳輸是基于二進制的,這會導(dǎo)致數(shù)據(jù)不易閱讀和調(diào)試。

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

(4)RPC的可擴展性較差,難以支持動態(tài)服務(wù)發(fā)現(xiàn)和負載均衡等功能。

03二者的選擇使用

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

wKgaomTVjh6ADxuuAACs9tCgRvs049.png

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

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

(1)在微服務(wù)架構(gòu)中,服務(wù)之間需要頻繁地進行內(nèi)部調(diào)用,RPC可以提供更高的性能和可靠性。

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

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

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

當(dāng)然這樣不是絕對固定的組合,也可以結(jié)合兩個協(xié)議來實現(xiàn)更好的網(wǎng)絡(luò),例如:

(1)我們可以在HTTP協(xié)議上封裝RPC協(xié)議,使得RPC請求可以通過HTTP代理或者網(wǎng)關(guān)來轉(zhuǎn)發(fā)和處理。

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

所以總的來說,RPC的出現(xiàn)是為了應(yīng)對HTTP協(xié)議滿足不了的對性能有所要求的網(wǎng)絡(luò)場景。它們并不是互斥的,而是可以根據(jù)不同的場景和需求進行選擇和組合的。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 接口
    +關(guān)注

    關(guān)注

    33

    文章

    9005

    瀏覽量

    153787
  • 服務(wù)器
    +關(guān)注

    關(guān)注

    13

    文章

    9797

    瀏覽量

    88047
  • HTTP
    +關(guān)注

    關(guān)注

    0

    文章

    525

    瀏覽量

    33561
  • TCP
    TCP
    +關(guān)注

    關(guān)注

    8

    文章

    1402

    瀏覽量

    81109
  • RPC
    RPC
    +關(guān)注

    關(guān)注

    0

    文章

    111

    瀏覽量

    11905

原文標(biāo)題:為什么有了HTTP,還需要RPC協(xié)議?

文章出處:【微信號:cdebyte,微信公眾號:億佰特物聯(lián)網(wǎng)應(yīng)用專家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    通信網(wǎng)絡(luò)技術(shù):RPC服務(wù)和HTTP服務(wù)的區(qū)別分析

    ! 本文簡單地介紹一下兩種形式的 C/S 架構(gòu),先說一下他們最本質(zhì)的區(qū)別,就是 RPC 主要是基于 TCP/IP 協(xié)議的,而 HTTP 服務(wù)主要是基于 HTTP
    的頭像 發(fā)表于 11-26 13:52 ?2934次閱讀

    什么是HTTP協(xié)議HTTP協(xié)議的基本特點和發(fā)展歷程

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

    為什么有了HTTP,還需要RPC協(xié)議?

    為什么有了HTTP,還需要RPC協(xié)議呢?在進行說明之前,首先我們需要了解什么是HTTP協(xié)議,什么是RPC
    的頭像 發(fā)表于 08-14 10:05 ?1259次閱讀
    為什么有了<b class='flag-5'>HTTP</b>,還需要<b class='flag-5'>RPC</b><b class='flag-5'>協(xié)議</b>?

    什么是Http協(xié)議

    文章目錄**1、說一下什么是Http協(xié)議?****2、什么是Http無狀態(tài)協(xié)議?怎么解決Http無狀態(tài)協(xié)
    發(fā)表于 12-22 06:27

    HTTP,HTTP協(xié)議的作用是什么?

    HTTP,HTTP協(xié)議的作用是什么? HTTP:Hypertext Transfer Protocol 超文本傳輸協(xié)議
    發(fā)表于 03-22 10:45 ?2.5w次閱讀

    HTTP協(xié)議培訓(xùn)教程資料

    HTTP協(xié)議培訓(xùn)教程資料 協(xié)議基礎(chǔ)  HTTP(HyperText Transfer Protocol)是超文本傳輸協(xié)議的縮寫,它用于傳送
    發(fā)表于 03-22 10:47 ?640次閱讀

    什么是RPC?為什么需要RPC

    首先要明確一點:RPC可以用HTTP協(xié)議實現(xiàn),并且用HTTP是建立在 TCP 之上最廣泛使用的 RPC,但是互聯(lián)網(wǎng)公司往往用自己的私有
    的頭像 發(fā)表于 04-16 12:49 ?1.5w次閱讀
    什么是<b class='flag-5'>RPC</b>?為什么需要<b class='flag-5'>RPC</b>?

    深入理解RPC自定義網(wǎng)絡(luò)協(xié)議

    只要涉及到網(wǎng)絡(luò)通信,必然涉及到網(wǎng)絡(luò)協(xié)議,應(yīng)用層也是一樣。在應(yīng)用層最標(biāo)準(zhǔn)和常用的就是HTTP協(xié)議。但在很多性能要求較高的場景各大企業(yè)內(nèi)部也會自定義的 RPC
    的頭像 發(fā)表于 06-12 15:00 ?2946次閱讀

    HTTPRPC

    TCP是傳輸層的協(xié)議,而基于TCP造出來的HTTP和各類RPC協(xié)議,它們都只是定義了不同消息格式的應(yīng)用層協(xié)議而已。
    的頭像 發(fā)表于 11-23 08:54 ?1215次閱讀
    <b class='flag-5'>HTTP</b>和<b class='flag-5'>RPC</b>

    大話HTTP協(xié)議前世今生

    HTTP 全稱 Hypertext Transfer Protocol,中文是超文本傳輸協(xié)議。網(wǎng)上講 HTTP 協(xié)議的資料可以說是五花八門,但大多數(shù)都在羅列
    的頭像 發(fā)表于 02-07 16:03 ?941次閱讀

    有了HTTP,為什么還要RPC?

    實際應(yīng)用過程中,五層協(xié)議結(jié)構(gòu)里面是沒有表示層和會話層的。應(yīng)該說它們和應(yīng)用層合并了。我們應(yīng)該將重點放在應(yīng)用層和傳輸層這兩個層面。因為HTTP是應(yīng)用層協(xié)議,而TCP是傳輸層協(xié)議。好,知道了
    的頭像 發(fā)表于 04-27 14:29 ?914次閱讀
    有了<b class='flag-5'>HTTP</b>,為什么還要<b class='flag-5'>RPC</b>?

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

    HTTP接口和RPC接口都是生產(chǎn)上常用的接口,顧名思義,HTTP接口使用基于HTTP協(xié)議的URL傳參調(diào)用,而
    發(fā)表于 06-13 09:18 ?1700次閱讀
    <b class='flag-5'>RPC</b>接口與<b class='flag-5'>HTTP</b>接口哪一個更好?

    基于Client/Server架構(gòu)的HTTP接口和RPC接口

    HTTP接口和RPC接口都是生產(chǎn)上常用的接口,顧名思義,HTTP接口使用基于HTTP協(xié)議的URL傳參調(diào)用,而
    發(fā)表于 06-13 09:18 ?993次閱讀
    基于Client/Server架構(gòu)的<b class='flag-5'>HTTP</b>接口和<b class='flag-5'>RPC</b>接口

    RPC接口和HTTP接口的區(qū)別與聯(lián)系

    基于遠程過程調(diào)用。 RPC(即Remote Procedure Call,遠程過程調(diào)用)和HTTP(HyperText Transfer Protocol,超文本傳輸協(xié)議),兩前者是
    的頭像 發(fā)表于 06-17 14:54 ?2258次閱讀
    <b class='flag-5'>RPC</b>接口和<b class='flag-5'>HTTP</b>接口的區(qū)別與聯(lián)系

    關(guān)于TCP、HTTP的知識科普

    要說http就繞不開tcp,TCP協(xié)議對應(yīng)于傳輸層,而HTTP協(xié)議對應(yīng)于應(yīng)用層,從本質(zhì)上來說,二者沒有可比性。但是,
    的頭像 發(fā)表于 12-21 09:31 ?1341次閱讀
    關(guān)于TCP、<b class='flag-5'>HTTP</b>的知識科普