很多人在學習java技術(shù)的時候,都對微服務框架這一塊不是很熟悉,本期java培訓教程教大家如何構(gòu)建微服務架構(gòu)?
java培訓教程分享:如何構(gòu)建微服務架構(gòu)?
微服務的拆分:
對于一般的公司而言,實踐微服務有非常大的技術(shù)挑戰(zhàn),所以并不是所有的公司都適合將單體架構(gòu)拆分成微服務架構(gòu)。一般來說,微服務架構(gòu)比較適合未來有一定的擴展復雜度,且有很大用戶增量預期的應用,例如一些新興的互聯(lián)網(wǎng)公司應用。這些公司在創(chuàng)業(yè)初期,不可能買大量的機器或者很貴的機器,但是又必須考慮應對成功后巨量的用戶問題,這時微服務架構(gòu)就成了最好的選擇。除此之外,對于那些項目規(guī)模較大、業(yè)務復雜度較高,且需要長期跟進的項目,也適合考慮使用微服務架構(gòu)。
在決定使用微服務架構(gòu)后,所面臨的另一個問題就是如何將系統(tǒng)拆分為微服務。對于微服務的拆分,可以參考如下幾點建議:
?、偻ㄟ^業(yè)務功能分解并定義與業(yè)務功能相對應的服務。
②將域驅(qū)動設計分解為多個子域。
?、郯凑談釉~或用例分解,并定義負責特定操作的服務。例如一個負責完成訂單的航運服務。
?、芡ㄟ^定義一個對給定類型的實體或資源的所有操作負責的服務來分解名詞或資源。例如一個負責管理用戶帳戶的帳戶服務。
由于每個公司項目的實際情況不同,所以微服務的拆分在實際操作時,會涉及到很多不同的細節(jié)問題,這里就不一一描述了,但總體來說,項目在拆分時按照上述幾點建議即可。
微服務架構(gòu)的組件:
我們先來了解下微服務架構(gòu)中所涉及到的一些常見組件。這些組件的名稱及其作用如下:
?、俜兆灾行模鹤韵到y(tǒng)中所有服務的地方;
?、诜兆裕悍仗峁┓綄⒆约赫{(diào)用地址注冊到服務注冊中心,讓服務調(diào)用方能夠方便地找到自己;
?、鄯瞻l(fā)現(xiàn):服務調(diào)用方從服務注冊中心找到自己需要調(diào)用服務的地址;
④負載均衡:服務提供方一般以多實例的形式提供服務,使用負載均衡能夠讓服務調(diào)用方連接到合適的服務節(jié)點;
?、莘杖蒎e:通過斷路器(也成熔斷器)等一系列的服務保護機制,保證服務調(diào)用者在調(diào)用異常服務時快速的返回結(jié)果,避免大量的同步等待。
?、薹站W(wǎng)關(guān):也稱為API網(wǎng)關(guān),是服務調(diào)用的唯一入口,可以在這個組件中實現(xiàn)用戶鑒權(quán)、動態(tài)路由、灰度發(fā)布、負載限流等功能;
?、叻植际脚渲弥行模簩⒈镜鼗呐渲眯畔?properties、yml、yaml等)注冊到配置中心,實現(xiàn)程序包在開發(fā)、測試、生產(chǎn)環(huán)境的無差別性,方便程序包的遷移。
微服務架構(gòu)的搭建:
通過前兩個小節(jié)的學習,我們已經(jīng)了解了如何將傳統(tǒng)業(yè)務拆分為微服務,并熟悉了微服務架構(gòu)中所涉及到的組件。為了使讀者在整體上對微服務架構(gòu)有一個認識,下面我們通過一張圖來講解如何搭建一個微服務架構(gòu),如圖。
圖中,部署了一系列的微服務,每個微服務都會訪問自己的數(shù)據(jù)庫(Database)。當這些微服務啟動時,會將其信息注冊到服務注冊中心(Service Registry), 在客戶端發(fā)送請求時,請求首先會被API網(wǎng)關(guān)(APIGateWay)攔截,API網(wǎng)關(guān)會讀取請求數(shù)據(jù),并從注冊中心獲取對應的服務信息,然后API網(wǎng)關(guān)會根據(jù)服務信息調(diào)用所需的微服務。
小提示:
圖中展示的只是一個簡單的微服務架構(gòu),然而要判斷一個架構(gòu)是否是微服務架構(gòu),還需要滿足以下幾點要求:
①根據(jù)業(yè)務模塊劃分服務種類;
?、诿總€服務可獨立部署且相互隔離;
?、弁ㄟ^輕量級API調(diào)用服務;
?、芊招璞WC良好的高可用性。
只有滿足以上幾點要求的架構(gòu),才能稱之為微服務架構(gòu),所以在搭建微服務架構(gòu)時,一定要注意這些問題。
以上就是詳細教程了,更多java培訓教程可聯(lián)系千鋒教育官方客服,可以點擊咨詢客服獲取試聽資格,讓你更快的掌握java技術(shù)。