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