分布式架構(gòu)設(shè)計概要總結(jié)_第1頁
分布式架構(gòu)設(shè)計概要總結(jié)_第2頁
分布式架構(gòu)設(shè)計概要總結(jié)_第3頁
分布式架構(gòu)設(shè)計概要總結(jié)_第4頁
分布式架構(gòu)設(shè)計概要總結(jié)_第5頁
已閱讀5頁,還剩7頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

分布式架構(gòu)設(shè)計概要總結(jié)一、構(gòu)建分布式的緣由——業(yè)務(wù)架構(gòu)的演進首先需要考慮的一點。我們先思考幾點:1、數(shù)據(jù)如何均勻分布到不同的節(jié)點上,涉及到負(fù)載均衡;之間的全都性;據(jù);paxos協(xié)議:paxos,要么全部失敗。在上圖簡潔以時間線為準(zhǔn),粗略描述了我們系統(tǒng)架構(gòu)隨著業(yè)務(wù)的需求考量以及業(yè)務(wù)的進展,系統(tǒng)擔(dān)當(dāng)?shù)牟l(fā)量也將逐步提升,這就要求我們的系統(tǒng)架構(gòu)而思考的方向可以從我們已有的計算機學(xué)問體系中找到答案。比方:份來緩解我們的壓力,即集群.庫的壓力反而增加了,于是我們會想到使用緩存策略來緩解我們的壓CPU的效勞進展改進。另外,隨著業(yè)務(wù)的增長以及需求不斷地調(diào)整變化,有時候為了提升我們beanbean冗余但可能是類型或者是狀態(tài)顯示不同,目的固然是簡化便于理解。更為專注業(yè)務(wù)開發(fā)的落地實現(xiàn)。引入性能技術(shù)的優(yōu)化方案之后,這個時候我們從另外一個視角來看,即一二、構(gòu)建分布式系統(tǒng)的兩個核心因素對此,一個分布式系統(tǒng)效勞需要具備以下兩個因素:其變成一個分布式的架構(gòu)。保證系統(tǒng)效勞的高可用:為了增大系統(tǒng)容量,我們將業(yè)務(wù)進展拆分,彼單點故障,從而提高系統(tǒng)的可用性。小結(jié)證我們的系統(tǒng)效勞具備高可用,抑或是允許一小局部效勞不行用。1、節(jié)點獨立完成業(yè)務(wù)的懇求處理操作。2、集群的一組業(yè)務(wù)效勞操作,這多個供給效勞的節(jié)點組成一個集群。3、副本節(jié)點的高可用。4、中間件用方案的組件,簡化開發(fā)人員的工作,讓開發(fā)者更專注于業(yè)務(wù)上的開發(fā)。比方效勞與效勞之間通過消息中間件實現(xiàn)異步通信,實現(xiàn)效勞解耦;緩存的過程,避開全部一樣的數(shù)據(jù)查詢操作的流量都落地到數(shù)據(jù)存儲層;引入負(fù)載均衡中間件實現(xiàn)高可用;CRUD5、SOA且通過網(wǎng)絡(luò)進展效勞調(diào)用來完成一次簡潔的業(yè)務(wù)懇求操作;而不影響微效勞中其他的組件。6、分布式協(xié)調(diào)執(zhí)行的業(yè)務(wù)規(guī)律處理挨次全都,即保證效勞節(jié)點處理業(yè)務(wù)請的規(guī)律具備有序性;資源的事務(wù)操作具備原子性以及數(shù)據(jù)全都性。全都性。7、效勞治理的架構(gòu)設(shè)計上來對待問題,那么效勞與效勞之間的通信流程如下:效勞啟動并注冊到注冊中心-調(diào)用方從注冊中心獵取被調(diào)用方的效勞列表統(tǒng)一存儲和治理,這樣子我們就能夠針對各個效勞進展分析與優(yōu)化等操作。8、DevOps&自動化運維CI/CD-UIDevOps程,這對于我們做效勞化架構(gòu)能夠?qū)崿F(xiàn)快速迭代開發(fā);移,配置治理,狀態(tài)治理等一系列自動化運維工作。四、分布式技術(shù)棧,對于高性能方面,自己也基于上述的根底上做一些補充:集群與負(fù)載均衡:通過水平擴展業(yè)務(wù)處理力氣來提升系統(tǒng)的并發(fā)處理能力。緩存設(shè)計:在我們的上述效勞進展水平抑或是垂直擴展的時候,這個時候上,為了緩解數(shù)據(jù)存儲系統(tǒng)的壓力,這個時候我們會考慮將數(shù)據(jù)進展冷熱劃分,對于熱點數(shù)據(jù)集中在緩存系統(tǒng)效勞以降低我們的數(shù)據(jù)存儲壓力。對于緩存的設(shè)計存在以下三種模式:CacheAside更模式,即失效-命中-更策略;cacheLinuxCachecachecache垂直拆分業(yè)務(wù)(效勞化設(shè)計):當(dāng)我們的一個效勞節(jié)點擔(dān)當(dāng)簡潔繁多的業(yè)務(wù)效勞的時候,必定會影響到我們業(yè)務(wù)處理的力氣,為了提升我們的并發(fā)處理力氣,為了提升我們的系統(tǒng)并發(fā)力氣,可以考慮將我們的業(yè)務(wù)進展垂直拆分,于是就有了一個懇求的處理需要多個效勞之間進展協(xié)作完成。數(shù)據(jù)鏡像與分區(qū)(讀寫分別/分庫分表):盡管使用緩存可以緩解我們的效勞壓力,但是照舊無法從根源上緩解流量對數(shù)據(jù)存儲的壓力,于是我們一方面會做讀寫分別,做主從集群,主節(jié)點負(fù)責(zé)處理事務(wù)的數(shù)據(jù)寫入,從節(jié)點數(shù)據(jù)負(fù)責(zé)數(shù)據(jù)的讀??;另一方面為了提升單庫單表的并發(fā)力氣,這個時候我們也是借助分而治之的設(shè)計思想,實行分庫分表的思路來緩解我們單庫單表的流量壓力。借助MQ中間件實現(xiàn)異步處理:可以通過中間件技術(shù)實現(xiàn)異步處理,對流量進展削峰緩沖,進一步提高了程序的并發(fā)處理力氣以及系統(tǒng)的穩(wěn)定性。數(shù)據(jù)異構(gòu)設(shè)計:將同一個業(yè)務(wù)數(shù)據(jù)依據(jù)業(yè)務(wù)需求的用途劃分為不同的數(shù)據(jù)倉庫存儲以適用相應(yīng)的業(yè)務(wù)需求場景,比方對于爬蟲的聚合資訊數(shù)據(jù)來源存在ID依據(jù)用戶維度來進展異構(gòu)一個與用戶相關(guān)的訂單數(shù)據(jù)倉庫的策略(存在數(shù)據(jù)冗余,但是提升讀取性能)。2、高可用設(shè)計一些補充:效勞冗余與負(fù)載均衡技術(shù):從集群角度上思考,我們需要考慮集群是流量如何分擔(dān)到集群效勞的節(jié)點,集群效勞節(jié)點消滅特別或者不行用的時候流量如何切換,這個時候我們就需要考慮到負(fù)載均衡技術(shù)來幫助我們實現(xiàn)流量分發(fā)的調(diào)度,對效勞節(jié)點實行心跳檢測以及當(dāng)效勞節(jié)點特別實行重試與流量切換重調(diào)度安排可用效勞節(jié)點來避開單點故障問題,簡而言之效勞的高可用可以是效勞冗余與負(fù)載均衡技術(shù)來避開單點故障,實現(xiàn)故障自動的恢復(fù)。隔離技術(shù):為了防止故障集中到其他效勞節(jié)點,我們通常會實行隔離技術(shù)來隔離拆分的業(yè)務(wù)效勞,每個業(yè)務(wù)效勞分別各自獨立部署,在分布式系統(tǒng)設(shè)計中,一般會效勞的種類或者是用戶來進展隔離。當(dāng)系統(tǒng)擔(dān)當(dāng)?shù)牟l(fā)流量效勞壓力格外浩大的時候,這個時候我們需要實行保護措施,通過降級或者限流的技術(shù)來停用局部業(yè)務(wù)效勞或者是拒絕局部用戶的懇求操作以確保整個系統(tǒng)不會被流量沖垮導(dǎo)致整體不行用。在效勞化架構(gòu)設(shè)計中,為了防止效勞產(chǎn)生雪崩,需要在調(diào)用效勞參與超時重試以及熔斷機制,避開將錯誤集中到其他效勞導(dǎo)致整個系統(tǒng)效勞不行用。從而縮小局部效勞。利用效勞冗余來避開單點故障,比方多租戶隔離,災(zāi)備多活抑或是數(shù)據(jù)副本保證全都性,高可用不僅是的效勞集群的高可用,還有就是中間件實現(xiàn)高可用設(shè)計。高可用的運維:實現(xiàn)devops的CI或者CD的持續(xù)集成打算任務(wù),能夠構(gòu)建執(zhí)行自動化測試,實現(xiàn)灰度公布部署以及線上系統(tǒng)的自動化把握。緩存的高可用:對于緩存系統(tǒng)也需要承受集群高可用的方式來避開單點故障以及實現(xiàn)故障恢復(fù),同時對于緩存系統(tǒng)要實現(xiàn)高可用,需要留意以下幾個問題:緩存穿透:即對于不存在的數(shù)據(jù)緩存始終都是沒有命中會直接將流量打到數(shù)據(jù)存儲層上。都會打到數(shù)據(jù)存儲層,很簡潔引起數(shù)據(jù)存儲層的并發(fā)性能問題。緩存擊穿:即針對某一個熱點緩存在某一個時間點存在并發(fā)訪問量請打到數(shù)據(jù)存層上。因此對于緩存的高可用不僅需要避開單點故障,同時還需要具備容錯能緩存擊穿的產(chǎn)生。切流量:面臨高并發(fā)流量的接入時,我們并無法保證全部效勞節(jié)點都是可用狀態(tài),于是需要在接入層或者效勞網(wǎng)關(guān)做故障轉(zhuǎn)移,將流量切換到可用的效勞節(jié)點上??苫貪L:在分布式的效勞化架構(gòu)設(shè)計,我們需要對效勞實施版本把握與治理,一旦公布的效勞節(jié)點產(chǎn)生測試不行預(yù)知的測試,為了削減效勞不行用時長抑或是效勞的掩蓋面,我們需要對效勞進展回滾到上一個穩(wěn)定版本以保證線上效勞可用。3、業(yè)務(wù)設(shè)計當(dāng)我們應(yīng)用在單位時間內(nèi)接收到一樣并發(fā)的事務(wù)懇求操作時,這個時候我們需要考慮事務(wù)懇求操作處理不管多少次懇求最終只能處理key。比方下單支付操作,由于支付渠道是無法避開重復(fù)支付的,因此對于我們key記錄在數(shù)據(jù)表并通過數(shù)據(jù)表進展查詢驗證,假設(shè)并發(fā)量很大的話,我們可以考MQMQ,再MQ事務(wù)補償機制:在分布式架構(gòu)設(shè)計中,基于ACID以及BASE理論學(xué)問,事務(wù)補償操作可以是保證一系列的業(yè)務(wù)操作具備原子性而最終到達(dá)業(yè)務(wù)數(shù)據(jù)全都性的目標(biāo),當(dāng)其中某一個操作消滅特別的時候,我們實行重試讓其運行得到我們期望的大事狀態(tài),假設(shè)重試不成功,則實行人工干預(yù)抑或是丟棄回滾大事。就需要對此場景進展事務(wù)補償,保證我們的業(yè)務(wù)最終全都性;N+1N+7試與驗證處理,保證數(shù)據(jù)金額的最終全都性.狀態(tài)機系統(tǒng)包含條件,大事以及大事觸發(fā)的狀態(tài)變更操作,嚴(yán)格依據(jù)確定的狀態(tài)變更規(guī)章通過外部大事觸發(fā)以及條件的推斷執(zhí)行狀態(tài)變更。比方設(shè)計一個訂單狀態(tài)的狀態(tài)機,我們需要考慮訂單狀態(tài)的變化以及對應(yīng)款狀態(tài)等一系列大事觸發(fā)的訂單狀態(tài)變更形成一個狀態(tài)機。可以針對一些核心業(yè)務(wù)功能實行行為記錄的日志異步化長期化到數(shù)據(jù)層上,并通過后臺治理系統(tǒng)查看反響以及重要核心業(yè)務(wù)流程的追蹤分析。五、分布式效勞指標(biāo)監(jiān)控時就需要對整個分布式系統(tǒng)進展全棧監(jiān)控,即不管是應(yīng)用效勞層(業(yè)務(wù)效勞化),抑或是平臺組件效勞還是底層機器的資源監(jiān)控,我們都需要做到心中有數(shù),才能夠針對某一個效勞進展排查與優(yōu)化。CPU/內(nèi)存/網(wǎng)絡(luò)/IO/帶寬流量等。Redis/MQ容量/io/內(nèi)存/線程/效勞節(jié)點安康狀態(tài)等指標(biāo)進展監(jiān)控。,效勞調(diào)用鏈,日志收集,qps/tps六、分布式小結(jié)1、分布式設(shè)計思考的維度兩個目標(biāo):提高系統(tǒng)的性能和保證系統(tǒng)效勞的高可用。宏觀的架構(gòu)技術(shù)棧:效勞/流量調(diào)度:流量把握-流量治理-效勞治理狀態(tài)/數(shù)據(jù)調(diào)度:數(shù)據(jù)可用性-數(shù)據(jù)全都性-數(shù)據(jù)分片DevOps環(huán)境公布-灰度公布-正式公布.業(yè)務(wù)效勞化設(shè)計:性能設(shè)計彈力設(shè)計(高可用技術(shù))業(yè)務(wù)設(shè)計全棧系統(tǒng)監(jiān)控2、分布式面臨需要解決的問題技術(shù)架構(gòu)面臨的問題:效勞節(jié)點如何崩潰恢復(fù)分布式緩存問題共識問題流量把握〔降級限流等策略〕整體架構(gòu)的監(jiān)控自動化運維效勞化架構(gòu)面臨的問題:數(shù)據(jù)全

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論