soa 微服務調用為啥用RPC框架,http不更簡單嗎?
微服務調用為啥用RPC框架,http不更簡單嗎?簡單一點,HTTP是協(xié)議,RPC是概念!RPC可以基于HTTP協(xié)議(feign)、TCP協(xié)議(netty)、RMI協(xié)議(soap)和web服務(XML-
微服務調用為啥用RPC框架,http不更簡單嗎?
簡單一點,HTTP是協(xié)議,RPC是概念!RPC可以基于HTTP協(xié)議(feign)、TCP協(xié)議(netty)、RMI協(xié)議(soap)和web服務(XML-RPC)框架實現(xiàn)。在傳輸過程中,由于序列化方法的不同,也出現(xiàn)了一些框架和協(xié)議,如Dubbo中的Dubbo協(xié)議、grpc protobuf序列化協(xié)議等。實際上,它們都是基于遠程調用的概念。什么是遠程呼叫?
關鍵是RPC是遠程調用。遠程調用是客戶端通過上述協(xié)議向服務器發(fā)送接口、參數(shù)、參數(shù)類型、方法、返回值、返回值類型等(稱為方法簽名),通知服務器要調用的接口方法。這個過程就是RPC的實現(xiàn)過程!HTTP和RPC是兩碼事
!在性能方面,HTTP本身是基于TCP協(xié)議的,屬于應用層協(xié)議,所以HTTP協(xié)議本身在實現(xiàn)過程中會占用大量的資源(內存、帶寬等)。在性能方面,它肯定不如直接通過TCP實現(xiàn)的RPC協(xié)議快。不管HTTP有多優(yōu)化,它絕對沒有TCP那么快!另一方面,TCP依賴于字節(jié)碼。目前常用的是將客戶端調用的接口信息以序列化的方式發(fā)送到服務器端。序列化框架包括許多內容(Hession、protobuf、kryo等)。Kryo具有最高的序列化性能,protobuf具有序列化后最小的字節(jié)碼)。序列化后的字節(jié)碼越小,占用的帶寬越小,序列化時間越長,線程IO延遲越短,線程IO延遲越小。因此,在具體的應用層,有很多技術可以討論。您可以根據(jù)自己的硬件能力選擇相應的技術
!歡迎熱愛科技的人們來探索
普通公司員工的編程水平與阿里巴巴有多大差距?
作為一名從事編程工作十多年的老程序員,雖然從未在阿里巴巴工作過,但他在跳槽時拒絕了百度和騰訊的邀請,選擇了一家更適合自己的互聯(lián)網(wǎng)公司。他的編程水平的主要決定因素是他有一個良好的環(huán)境來培養(yǎng)他的基本技能。日前,他回答了一個問題,即哪個公司的編碼水平高還是低,對于大公司還是小公司來說都有外部因素,但主要還是自己的。他們沒有決心提高自己的編碼水平。不管外部環(huán)境有多好,都沒有多大意義。
由于阿里巴巴等大公司的全方位安排,提交代碼通常需要得到領導的批準,這樣可以在一定程度上大大提高代碼的質量。審計機制將更加嚴格,測試控制也將更加嚴格。普通的小公司在人員配備上可能會少一點,控制也會在一定程度上差一點,嚴格規(guī)范的制度可以促進程序員更深層次的提高,但實質上是他們是否想做得更好,是否想提高得更快。
事實上,說到阿里巴巴這樣的大公司,主要是人們的心態(tài)問題。他們認為大公司必須比小公司更標準化。那些經(jīng)歷過大公司的人仍然認為他們只是其中的一個螺絲釘。他們還想去小公司,讓他們玩得更徹底。小公司的人渴望大公司的待遇和標準化。就像未婚的人一樣,他們總是想進入被圍困的城市,他們羨慕未婚者的自由。其實,來回是一回事。
有一次,為了進入一家大公司,我放棄了一家中型公司的技術經(jīng)理職位?,F(xiàn)在,這不值得想象。當我進入一家成熟的大公司時,我的貢獻只是滄海一粟。很難上去,真正的機會還在初創(chuàng)公司或中小企業(yè)。當然,這些東西需要親身經(jīng)歷,當你年輕充滿活力的時候,你會覺得很難欣賞。你只是覺得自己做出了正確的選擇和實踐,把真理和知識區(qū)別開來。
我希望我能幫助你。