RPC
RPC(Remote Procedure Call)遠程過程調(diào)用檐盟,主要解決遠程通信間的問題,不需要了解底層網(wǎng)絡(luò)的通信機制。
RPC框架
知名度較高的有Thrift(FB的)、dubbo(阿里的)奔穿。
RPC的一般需要經(jīng)歷4個步驟:
1、建立通信
首先要解決通訊的問題:即A機器想要調(diào)用B機器敏晤,首先得建立起通信連接贱田,主要是通過在客戶端和服務(wù)器之間建立TCP連接。
2茵典、服務(wù)尋址
要解決尋址的問題湘换,A服務(wù)器上如何連接到B服務(wù)器(如主機或IP地址)以及特定的端口,方法的名稱是什么统阿。
3彩倚、網(wǎng)絡(luò)傳輸
1)序列化
當(dāng)A服務(wù)器上的應(yīng)用發(fā)起一個RPC調(diào)用時,調(diào)用方法和參數(shù)數(shù)據(jù)都需要先進行序列化扶平。
2)反序列化
當(dāng)B服務(wù)器接收到A服務(wù)器的請求之后帆离,又需要對接收到的參數(shù)等信息進行反序列化操作。
4结澄、服務(wù)調(diào)用
B服務(wù)器進行本地調(diào)用(通過代理Proxy)之后得到了返回值哥谷,此時還需要再把返回值發(fā)送回A服務(wù)器,同樣也需要經(jīng)過序列化操作麻献,然后再經(jīng)過網(wǎng)絡(luò)傳輸將二進制數(shù)據(jù)發(fā)送回A服務(wù)器们妥。
通常,一次完整的PRC調(diào)用需要經(jīng)歷如上4個步驟勉吻。
更加詳細(xì)的RPC介紹监婶,參考我的往期文章:《高并發(fā)架構(gòu)系列:RPC框架的實現(xiàn)原理,調(diào)用全過程齿桃,及RPC架構(gòu)組件》
MQ(消息隊列)
消息隊列(MQ)是一種能實現(xiàn)生產(chǎn)者到消費者單向通信的通信模型惑惶,一般來說是指實現(xiàn)這個模型的中間件。
典型的MQ中間件:
RabbitMQ短纵、ActiveMQ带污、Kafka等
典型的特點:
1、解耦
2香到、可靠投遞
3鱼冀、廣播
4报破、最終一致性
5、流量削峰
6雷绢、消息投遞保證
7泛烙、異步通信(支持同步)
8、提高系統(tǒng)吞吐翘紊、健壯性
典型的使用場景:
秒殺業(yè)務(wù)中利用MQ來實現(xiàn)流量削峰蔽氨,以及應(yīng)用解耦使用。
RPC和MQ的區(qū)別和關(guān)聯(lián):
1.在架構(gòu)上帆疟,RPC和MQ的差異點是鹉究,Message有一個中間結(jié)點Message Queue,可以把消息存儲踪宠。
2.同步調(diào)用:對于要立即等待返回處理結(jié)果的場景自赔,RPC是首選。
3.MQ 的使用柳琢,一方面是基于性能的考慮绍妨,比如服務(wù)端不能快速的響應(yīng)客戶端(或客戶端也不要求實時響應(yīng)),需要在隊列里緩存柬脸。
另外一方面他去,它更側(cè)重數(shù)據(jù)的傳輸,因此方式更加多樣化倒堕,除了點對點外灾测,還有訂閱發(fā)布等功能。
4.而且隨著業(yè)務(wù)增長垦巴,有的處理端處理量會成為瓶頸媳搪,會進行同步調(diào)用改造為異步調(diào)用,這個時候可以考慮使用MQ骤宣。
詳細(xì)的MQ消息隊列的選型比較秦爆,參考《阿里P8架構(gòu)師談:主流的消息隊列MQ比較,詳解MQ的4類應(yīng)用場景》憔披。
以上是就是RPC和MQ消息隊列的區(qū)別介紹鲜结。
覺得不錯請點贊支持,歡迎留言或進我的個人群179961551領(lǐng)取【架構(gòu)資料專題目合集90期】活逆、【BATJTMD大廠JAVA面試真題1000+】,本群專用于學(xué)習(xí)交流技術(shù)拗胜、分享面試機會蔗候,拒絕廣告,我也會在群內(nèi)不定期答題埂软、探討锈遥。