黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節(jié)點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學(xué)習(xí)攻略 Java學(xué)習(xí) Java框架教程之RPC框架介紹

Java框架教程之RPC框架介紹

更新時間:2020-05-29 14:22:03 來源:動力節(jié)點 瀏覽4450次

關(guān)于RPC框架,首先了解什么叫RPC,為什么要RPC,RPC是指遠程過程調(diào)用,也就是說兩臺服務(wù)器A,B,一個應(yīng)用部署在A服務(wù)器上,想要調(diào)用B服務(wù)器上應(yīng)用提供的函數(shù)/方法,由于不在一個內(nèi)存空間,不能直接調(diào)用,需要通過網(wǎng)絡(luò)來表達調(diào)用的語義和傳達調(diào)用的數(shù)據(jù)。

比如說,一個方法可能是這樣定義的:

Employee getEmployeeByName(String fullName)

那么:

首先,要解決通訊的問題,主要是通過在客戶端和服務(wù)器之間建立TCP連接,遠程過程調(diào)用的所有交換的數(shù)據(jù)都在這個連接里傳輸。連接可以是按需連接,調(diào)用結(jié)束后就斷掉,也可以是長連接,多個遠程過程調(diào)用共享同一個連接。

第二,要解決尋址的問題,也就是說,A服務(wù)器上的應(yīng)用怎么告訴底層的RPC框架,如何連接到B服務(wù)器(如主機或IP地址)以及特定的端口,方法的名稱名稱是什么,這樣才能完成調(diào)用。比如基于Web服務(wù)協(xié)議棧的RPC,就要提供一個endpoint URI,或者是從UDDI服務(wù)上查找。如果是RMI調(diào)用的話,還需要一個RMI Registry來注冊服務(wù)的地址。

第三,當(dāng)A服務(wù)器上的應(yīng)用發(fā)起遠程過程調(diào)用時,方法的參數(shù)需要通過底層的網(wǎng)絡(luò)協(xié)議如TCP傳遞到B服務(wù)器,由于網(wǎng)絡(luò)協(xié)議是基于二進制的,內(nèi)存中的參數(shù)的值要序列化成二進制的形式,也就是序列化(Serialize)或編組(marshal),通過尋址和傳輸將序列化的二進制發(fā)送給B服務(wù)器。

第四,B服務(wù)器收到請求后,需要對參數(shù)進行反序列化(序列化的逆操作),恢復(fù)為內(nèi)存中的表達方式,然后找到對應(yīng)的方法(尋址的一部分)進行本地調(diào)用,然后得到返回值。

第五,返回值還要發(fā)送回服務(wù)器A上的應(yīng)用,也要經(jīng)過序列化的方式發(fā)送,服務(wù)器A接到后,再反序列化,恢復(fù)為內(nèi)存中的表達方式,交給A服務(wù)器上的應(yīng)用

Java框架教程之RPC框架介紹

為什么RPC呢?就是無法在一個進程內(nèi),甚至一個計算機內(nèi)通過本地調(diào)用的方式完成的需求,比如比如不同的系統(tǒng)間的通訊,甚至不同的組織間的通訊。由于計算能力需要橫向擴展,需要在多臺機器組成的集群上部署應(yīng)用,

RPC的協(xié)議有很多,比如最早的CORBA,Java RMI,Web Service的RPC風(fēng)格,Hessian,Thrift,甚至Rest API。

關(guān)于Netty

而Netty框架不局限于RPC,更多的是作為一種網(wǎng)絡(luò)協(xié)議的實現(xiàn)框架,比如HTTP,由于RPC需要高效的網(wǎng)絡(luò)通信,就可能選擇以Netty作為基礎(chǔ)。除了網(wǎng)絡(luò)通信,RPC還需要有比較高效的序列化框架,以及一種尋址方式。如果是帶會話(狀態(tài))的RPC調(diào)用,還需要有會話和狀態(tài)保持的功能。

大體上來說,Netty就是提供一種事件驅(qū)動的,責(zé)任鏈?zhǔn)剑ㄒ部梢哉f是流水線)的網(wǎng)絡(luò)協(xié)議實現(xiàn)方式。網(wǎng)絡(luò)協(xié)議包含很多層次,很多部分組成,如傳輸層協(xié)議,編碼解碼,壓縮解壓,身份認(rèn)證,加密解密,請求的處理邏輯,怎么能夠更好的復(fù)用,擴展,業(yè)界通用的方法就是責(zé)任鏈,

一個請求應(yīng)答網(wǎng)絡(luò)交互通常包含兩條鏈,一條鏈(Upstream)是從傳輸層,經(jīng)過一系列步驟,如身份認(rèn)證,解密,日志,流控,最后到達業(yè)務(wù)層,一條鏈(DownStream)是業(yè)務(wù)層返回后,又經(jīng)過一系列步驟,如加密等,又回到傳輸層。

Java框架教程之RPC框架介紹

這樣每一層都有一個處理接口,都可以進行不同的操作,比如身份認(rèn)證,加解密,日志,流控,將不同的處理實現(xiàn)像拼積木那樣插接起來就可以實現(xiàn)一個網(wǎng)絡(luò)協(xié)議了(快速開發(fā))。每一層都有自己的實現(xiàn),上層不需要關(guān)注面向網(wǎng)絡(luò)的操作(可維護)。Netty已經(jīng)提供了很多實現(xiàn)。

Java框架教程之RPC框架介紹

當(dāng)然Netty還有許多好處,比如對非阻塞IO(NIO)的支持,比如在鏈上傳遞時最大程度的減少buffer的copy(高性能)。

以上就是動力節(jié)點java培訓(xùn)機構(gòu)的小編針對“Java框架教程之RPC框架介紹”的內(nèi)容進行的回答,希望對大家有所幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為你服務(wù)。

提交申請后,顧問老師會電話與您溝通安排學(xué)習(xí)

免費課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 天天插日日射 | 亚洲国产日韩欧美综合久久 | 日韩伦理一区二区三区 | 九九亚洲视频 | 一级特黄性色生活片一区二区 | 日本在线一本 | 国产91在线视频 | 成人免费在线播放视频 | 成人羞羞视频在线观看 | 一区二区三区四区视频在线 | 欧美xxxwww| 国产99视频精品免费视频7 | 国产三级精品在线 | 亚洲日本香蕉视频 | 国产免费不卡v片在线观看 国产免费播放一区二区三区 | 123日本不卡在线观看 | 福利网站导航 | 国产精品一区高清在线观看 | 亚洲三级天堂 | 亚洲动漫第一页 | 99久久网站| 深爱激情成人 | 午夜天堂在线观看 | 伊人五月 | 免费大片a一级一级 | 黄色大片在线看 | 久久精品久久精品国产大片 | 国产精品成在线观看 | 国产免费爽爽视频免费可以看 | 午夜影院免费看 | 日本一区二区三区中文字幕视频 | 最近中文字幕 | 天天摸天天做天天爽天天弄 | 久热这里只有精品视频6 | 亚洲欧美强伦一区二区另类 | 成人a毛片在线看免费全部播放 | 久久亚洲国产视频 | 天天舔天天射天天干 | 久久激情视频 | 黄网站色| 日本一区二区三 |