api大全 微服務(wù)調(diào)用為啥用RPC框架,http不更簡單嗎?
微服務(wù)調(diào)用為啥用RPC框架,http不更簡單嗎?簡單一點,HTTP是協(xié)議,RPC是概念!RPC可以基于HTTP協(xié)議(feign)、TCP協(xié)議(netty)、RMI協(xié)議(soap)和web服務(wù)(XML-
微服務(wù)調(diào)用為啥用RPC框架,http不更簡單嗎?
簡單一點,HTTP是協(xié)議,RPC是概念!RPC可以基于HTTP協(xié)議(feign)、TCP協(xié)議(netty)、RMI協(xié)議(soap)和web服務(wù)(XML-RPC)框架實現(xiàn)。在傳輸過程中,由于序列化方法的不同,也出現(xiàn)了一些框架和協(xié)議,如Dubbo中的Dubbo協(xié)議、grpc protobuf序列化協(xié)議等。實際上,它們都是基于遠(yuǎn)程調(diào)用的概念。什么是遠(yuǎn)程呼叫?
關(guān)鍵是RPC是遠(yuǎn)程調(diào)用。遠(yuǎn)程調(diào)用是客戶端通過上述協(xié)議向服務(wù)器發(fā)送接口、參數(shù)、參數(shù)類型、方法、返回值、返回值類型等(稱為方法簽名),通知服務(wù)器要調(diào)用的接口方法。這個過程就是RPC的實現(xiàn)過程!HTTP和RPC是兩碼事
!在性能方面,HTTP本身是基于TCP協(xié)議的,屬于應(yīng)用層協(xié)議,所以HTTP協(xié)議本身在實現(xiàn)過程中會占用大量的資源(內(nèi)存、帶寬等)。在性能方面,它肯定不如直接通過TCP實現(xiàn)的RPC協(xié)議快。不管HTTP有多優(yōu)化,它絕對沒有TCP那么快!另一方面,TCP依賴于字節(jié)碼。目前常用的是將客戶端調(diào)用的接口信息以序列化的方式發(fā)送到服務(wù)器端。序列化框架包括許多內(nèi)容(Hession、protobuf、kryo等)。Kryo具有最高的序列化性能,protobuf具有序列化后最小的字節(jié)碼)。序列化后的字節(jié)碼越小,占用的帶寬越小,序列化時間越長,線程IO延遲越短,線程IO延遲越小。因此,在具體的應(yīng)用層,有很多技術(shù)可以討論。您可以根據(jù)自己的硬件能力選擇相應(yīng)的技術(shù)
!歡迎熱愛科技的人們來探索
什么是網(wǎng)關(guān),網(wǎng)關(guān)的作用是什么?
感謝您的邀請。這是一個簡短的版本!我在學(xué)習(xí)的時候沒有說清楚。再去學(xué)習(xí)!網(wǎng)關(guān):連接兩個網(wǎng)絡(luò)的設(shè)備。對于語音網(wǎng)關(guān),它可以連接PSTN網(wǎng)絡(luò)和以太網(wǎng),相當(dāng)于VoIP。它通過網(wǎng)關(guān)將不同手機(jī)中的模擬信號轉(zhuǎn)換成數(shù)字信號,然后加入?yún)f(xié)議進(jìn)行傳輸。當(dāng)它到達(dá)接收端時,它將通過網(wǎng)關(guān)恢復(fù)為模擬電話信號,最后在電話上可以聽到。首先,它支持鄰居獲取機(jī)制,允許一個路由器請求另一個路由器同意交換可到達(dá)的信息。我們可以說一個路由器獲得一個EGP對等路由器或一個EGP鄰居。EGP對等路由器在交換路由信息的意義上只是一個鄰居,與它的地理位置無關(guān)。2、 路由器不斷測試它的EGP鄰居是否能響應(yīng)。3、 EGP相鄰站周期性地發(fā)送路由更新消息。交換網(wǎng)絡(luò)可訪問的信息。(圖片:來自互聯(lián)網(wǎng))
Service層和Dao層真的有必要每個類都加上接口嗎?
這主要取決于您的項目:
例如,項目中使用的原始hibernate可能需要稍后切換到mybatis,因此Dao需要使用該接口。這不會影響上層代碼的更改。
另一個例子是,項目是一個單一的應(yīng)用程序。任何代碼修改都需要重新編譯整個項目,因此不需要接口。如果項目是由模塊編譯和部署的,那么可以使用接口解耦。假設(shè)修改了Dao,只需要重新編譯和部署Dao模塊,而不影響上層模塊。
此外,如果項目團(tuán)隊中有許多新手,簡單的代碼結(jié)構(gòu)可能更合適。復(fù)雜項目結(jié)構(gòu)的學(xué)習(xí)成本較高。
如果工程進(jìn)度非常緊迫,我們可以用簡單粗暴的方式用經(jīng)濟(jì)成本來說明原因。
使用接口的成本是不使用接口的成本(包括后續(xù)維護(hù)成本)。
如果項目變化很大,部署了模塊,項目不急,使用接口的成本比不使用接口的成本低,雖然早期不使用接口似乎更簡單;相反,不使用接口的成本低,而且連框架都不能用~
畢竟工具是提高效率的,那你為什么不能和自己相處呢!