亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專(zhuān)欄INFORMATION COLUMN

《大型網(wǎng)站系統(tǒng)與Java中間件》讀書(shū)筆記 (中)

fredshare / 1191人閱讀

摘要:文本已收錄至我的倉(cāng)庫(kù),歡迎回顧上一篇大型網(wǎng)站系統(tǒng)與中間件讀書(shū)筆記一這周周末讀了第四章,現(xiàn)在過(guò)來(lái)做做筆記,希望能幫助到大家。沒(méi)錯(cuò),我們通過(guò)肯定是可以完成兩個(gè)系統(tǒng)之間的通信的問(wèn)題的。

前言
只有光頭才能變強(qiáng)。

文本已收錄至我的GitHub倉(cāng)庫(kù),歡迎Star:https://github.com/ZhongFuCheng3y/3y

回顧上一篇:

《大型網(wǎng)站系統(tǒng)與Java中間件》讀書(shū)筆記(一)

這周周末讀了第四章,現(xiàn)在過(guò)來(lái)做做筆記,希望能幫助到大家。

注:在看這篇文章之前,強(qiáng)烈建議先看看我之前寫(xiě)過(guò)的一篇SpringCloud入門(mén)文章:外行人都能看懂的SpringCloud,錯(cuò)過(guò)了血虧!??赐暝倩仡^看這篇文章,你會(huì)發(fā)現(xiàn):這本書(shū)講的設(shè)計(jì)與實(shí)現(xiàn)在SpringCloud中幾乎都有對(duì)應(yīng)的組件支持。

一、服務(wù)框架的設(shè)計(jì)

從上一篇我們講到,應(yīng)用拆開(kāi)了以后,不同功能/模塊之間的調(diào)用不再單純通過(guò)本機(jī)調(diào)用,引入了遠(yuǎn)程的服務(wù)調(diào)用。

而遠(yuǎn)程的服務(wù)調(diào)用這個(gè)東東會(huì)很難嗎?說(shuō)白了,不就是兩臺(tái)服務(wù)器之間通信嗎?

這時(shí)候,你能想到什么?必定是Socket吧。沒(méi)錯(cuò),我們通過(guò)Socket肯定是可以完成兩個(gè)系統(tǒng)之間的通信的問(wèn)題的。(Socket相信大家在學(xué)習(xí)基礎(chǔ)的時(shí)候已經(jīng)寫(xiě)過(guò)Demo了,這我就不多BB了)

一兩個(gè)系統(tǒng)的Socket寫(xiě)起來(lái)沒(méi)啥,但我們應(yīng)用拆分之后,系統(tǒng)可是會(huì)變得很多很多。

系統(tǒng)很多的情況下,我們?cè)趯?xiě)遠(yuǎn)程調(diào)用代碼的時(shí)候就可能要考慮到以下的問(wèn)題:

我們肯定是不希望每次遠(yuǎn)程調(diào)用的時(shí)候都貼上重復(fù)的Socket代碼,要是調(diào)用遠(yuǎn)程方法像調(diào)用本地方法一樣簡(jiǎn)單就好了。

某個(gè)服務(wù)應(yīng)用為了實(shí)現(xiàn)高可用,集群了(多臺(tái)機(jī)器部署同一套應(yīng)用)。那我遠(yuǎn)程調(diào)用的時(shí)候選擇哪一臺(tái)機(jī)器進(jìn)行調(diào)用?

網(wǎng)絡(luò)之間的傳輸協(xié)議用現(xiàn)成的HTTP呢?還是自定義一套通信協(xié)議呢?

因?yàn)槲覀兿胝{(diào)用遠(yuǎn)程方法像調(diào)用本地方法一樣,那么在網(wǎng)絡(luò)上就需要傳輸Java對(duì)象,要傳輸Java對(duì)象,就必須得對(duì)其進(jìn)行序列化和反序列化的處理。能實(shí)現(xiàn)序列化的操作也有很多,選擇哪一種方式呢?

網(wǎng)絡(luò)之間的通訊也有bio、nio、以及aio這幾種模式,一般來(lái)說(shuō)我們會(huì)選擇哪種比較多?如果不了解nio的同學(xué),可以閱讀我以前寫(xiě)過(guò)的筆記(nio你了解多少?)

….等等等

由于系統(tǒng)之間的調(diào)用會(huì)非常多,我們自然是不希望寫(xiě)重復(fù)的代碼的,所以服務(wù)框架(也可以說(shuō)是RPC框架)就應(yīng)運(yùn)而生了【說(shuō)白了就是專(zhuān)門(mén)處理遠(yuǎn)程服務(wù)調(diào)用的框架】。有了服務(wù)框架,我們就可以實(shí)現(xiàn)多個(gè)系統(tǒng)之間以統(tǒng)一的方式來(lái)進(jìn)行遠(yuǎn)程調(diào)用了。

推薦閱讀:RPC太太太太太太太容易理解啦!

一個(gè)服務(wù)框架需要考慮的問(wèn)題其實(shí)遠(yuǎn)不止上面所列出的那些,比如說(shuō):

服務(wù)框架與Web應(yīng)用和Web容器的關(guān)系是什么?服務(wù)框架和應(yīng)用是綁定在一起嗎?(服務(wù)框架作為Web應(yīng)用的一個(gè)依賴包),還是說(shuō)服務(wù)框架只是Web應(yīng)用的一個(gè)擴(kuò)展(沒(méi)有和Web應(yīng)用打包綁定在一起)

服務(wù)框架的jar包和Web應(yīng)用的jar包沖突了怎么辦?

為了保證系統(tǒng)的穩(wěn)定性,流量控制也應(yīng)該要考慮到

在遠(yuǎn)程調(diào)用的時(shí)候,需不需要以更細(xì)粒度的方式來(lái)進(jìn)行選擇(之前說(shuō)的是選擇哪臺(tái)機(jī)器,但可以細(xì)粒度到機(jī)器下的接口或者方法)

....等等

二、服務(wù)框架的技術(shù)實(shí)現(xiàn)思路

在書(shū)中給出了設(shè)計(jì)服務(wù)框架時(shí)需要考慮的問(wèn)題的同時(shí)也給出了一些實(shí)現(xiàn)思路,我摘錄一些我覺(jué)得比較有參考意義的說(shuō)說(shuō)。

2.1 像本地一樣調(diào)用遠(yuǎn)程服務(wù)
比如服務(wù)消費(fèi)方在執(zhí)行orderService.buy("HHKB鍵盤(pán)")時(shí),實(shí)質(zhì)上調(diào)用的是遠(yuǎn)端的服務(wù)。

這用到啥技術(shù)?明顯就是動(dòng)態(tài)代理(給女朋友講解什么是代理模式)

在實(shí)現(xiàn)的時(shí)候有三個(gè)基礎(chǔ)屬性可以參考一下:

interfaceName— 確定調(diào)用的是哪一個(gè)接口

version— 如果接口進(jìn)行升級(jí)了,可以使用version來(lái)進(jìn)行區(qū)分和隔離

group— 對(duì)遠(yuǎn)程服務(wù)的機(jī)器進(jìn)行分組,那么調(diào)用的時(shí)候就可以選擇不同的分組來(lái)調(diào)用(調(diào)用者對(duì)統(tǒng)一服務(wù)的調(diào)用進(jìn)行隔離)

2.2 其他

當(dāng)遠(yuǎn)程調(diào)用服務(wù)的時(shí)候,不需要每次都要去注冊(cè)中心查找可用的地址,而是把地址緩存在調(diào)用方。當(dāng)服務(wù)有變化的時(shí)候,主動(dòng)告訴調(diào)用者就行了。

流量控制一般會(huì)基于兩個(gè)維度去考慮:一、自身的接口和方法。二、請(qǐng)求的來(lái)源

并不是所有的請(qǐng)求都要經(jīng)過(guò)服務(wù)提供者。像走緩存這樣頻繁的操作(而且大多數(shù)都是會(huì)成功的),直接在調(diào)用方調(diào)用就ok了

最后

總的來(lái)說(shuō),書(shū)的第四章主要是在講解在設(shè)計(jì)服務(wù)框架的時(shí)候應(yīng)該要考慮到哪些方面,可以以什么方案來(lái)解決,看得還是非常過(guò)癮的(這只是我的個(gè)人筆記,書(shū)上還有很多的內(nèi)容)。強(qiáng)烈建議配合我之前寫(xiě)過(guò)的一篇SpringCloud入門(mén)文章:外行人都能看懂的SpringCloud,錯(cuò)過(guò)了血虧!食用。

樂(lè)于輸出干貨的Java技術(shù)公眾號(hào):Java3y。公眾號(hào)內(nèi)有200多篇原創(chuàng)技術(shù)文章、海量視頻資源、精美腦圖,關(guān)注即可獲?。?/strong>

覺(jué)得我的文章寫(xiě)得不錯(cuò),點(diǎn)!

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/75119.html

相關(guān)文章

  • 大型網(wǎng)站系統(tǒng)Java間件讀書(shū)筆記(上)

    摘要:另一個(gè)用戶請(qǐng)求過(guò)來(lái),負(fù)載均衡器指派這個(gè)請(qǐng)求到服務(wù)器。這樣就平攤了請(qǐng)求這種方式就叫做輪詢策略還有很多種,就看你想怎么實(shí)現(xiàn)了,反正這個(gè)邏輯的代碼放在負(fù)載均衡器上。 前言 只有光頭才能變強(qiáng)。文本已收錄至我的GitHub倉(cāng)庫(kù),歡迎Star:https://github.com/ZhongFuCheng3y/3y 這本書(shū)買(mǎi)了一段時(shí)間了,之前在杭州沒(méi)帶過(guò)去,現(xiàn)在讀完第三章,來(lái)做做筆記 showI...

    baukh789 評(píng)論0 收藏0
  • 那些年我看過(guò)的書(shū) —— 致敬我的大學(xué)生活 —— Say Good Bye !

    摘要:開(kāi)頭正式開(kāi)啟我入職的里程,現(xiàn)在已是工作了一個(gè)星期了,這個(gè)星期算是我入職的過(guò)渡期,算是知道了學(xué)校生活和工作的差距了,總之,盡快習(xí)慣這種生活吧。當(dāng)時(shí)是看的廖雪峰的博客自己也用做爬蟲(chóng)寫(xiě)過(guò)幾篇博客,不過(guò)有些是在前人的基礎(chǔ)上寫(xiě)的。 showImg(https://segmentfault.com/img/remote/1460000010867984); 開(kāi)頭 2017.08.21 正式開(kāi)啟我...

    xiaoqibTn 評(píng)論0 收藏0
  • 讀書(shū)筆記大型分布式網(wǎng)站架構(gòu)設(shè)計(jì)實(shí)踐.分布式緩存

    摘要:接下來(lái)將介紹分布式緩存的典型代表,以及分布式緩存的應(yīng)用場(chǎng)景。的分布式實(shí)現(xiàn)本身并不是一種分布式的緩存系統(tǒng),它的分布式是由訪問(wèn)它的客戶端來(lái)實(shí)現(xiàn)的。 前言:本書(shū)是對(duì)分布式系統(tǒng)架構(gòu)涉及到的相關(guān)技術(shù)的一本科普書(shū)籍。由于很難作為開(kāi)發(fā)參考,只能但求了解。所以通篇淺讀,對(duì)分布式系統(tǒng)進(jìn)行大致的了解。因?yàn)閷?xiě)的非常好,感覺(jué)非常有意思,自己也做不出總結(jié)。所謂的讀書(shū)筆記也就演變成了摘抄。 簡(jiǎn)介 一個(gè)大型、穩(wěn)健、...

    pepperwang 評(píng)論0 收藏0
  • 從小白程序員一路晉升為大廠高級(jí)技術(shù)專(zhuān)家我看過(guò)哪些書(shū)籍?(建議收藏)

    摘要:大家好,我是冰河有句話叫做投資啥都不如投資自己的回報(bào)率高。馬上就十一國(guó)慶假期了,給小伙伴們分享下,從小白程序員到大廠高級(jí)技術(shù)專(zhuān)家我看過(guò)哪些技術(shù)類(lèi)書(shū)籍。 大家好,我是...

    sf_wangchong 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

fredshare

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<