架構基本概念和架構本質

来源:https://www.cnblogs.com/samdyli/archive/2020/03/22/12546863.html
-Advertisement-
Play Games

CSDN看到一篇介紹架構設計的博客,內容提綱挈領,內容豐富。依據原文整理,加上自己的理解和總結。 推薦給大家。點擊原文可以查看出處。 原文鏈接:https://blog.csdn.net/hguisu/article/details/78258430 什麼是架構和架構本質 在軟體行業,對於什麼是架構 ...


CSDN看到一篇介紹架構設計的博客,內容提綱挈領,內容豐富。依據原文整理,加上自己的理解和總結。 推薦給大家。點擊原文可以查看出處。

原文鏈接:https://blog.csdn.net/hguisu/article/details/78258430

什麼是架構和架構本質

在軟體行業,對於什麼是架構,都有很多的爭論,每個人都有自己的理解。此君說的架構和彼君理解的架構未必是一回事。因此我們在討論架構之前,我們先討論架構的概念定義,概念是人認識這個世界的基礎,並用來溝通的手段,如果對架構概念理解不一樣,那溝通起來自然不順暢。

Linux有架構,MySQL有架構,JVM也有架構,使用Java開發、MySQL存儲、跑在Linux上的業務系統也有架構,應該關註哪一個?

想要清楚以上問題需要梳理幾個有關係又相似的概念:系統與子系統、模塊與組建、框架與架構:

區分系統、模塊、組件、框架和架構

S君: 區分系統、模塊、組件、框架和架構

  • 系統(system)和子系統:有關聯的個體,根據某種規則運行,共同完成獨特的功能。子系統:系統的組成部分。

  • 模塊(module)和組件(component):模塊和組件都是系統的組成部分,只是從不同角度拆分系統而已。 從邏輯角度拆分得到的是模塊,從物理角度拆分得到的是組件。 模塊是為了實現職責分離, 組件是為了實現復用。

  • 框架:為了實現某個業界標準或完成特定基本任務的軟體組件規範,按照規範提供所要求基礎功能的軟體產品。

  • 架構:頂層設計

系統與子系統

系統:泛指由一群有關聯的個體組成,根據某種規則運作,能完成個別元件不能獨立完成的工作能力的群體。

子系統:也是由一群關聯的個體組成的系統,多半是在更大的系統中的一部分。

模塊與組件

都是系統的組成部分,從不同角度拆分系統而已。模塊是邏輯單元,組件是物理單元。

模塊就是從邏輯上將系統分解, 即分而治之, 將複雜問題簡單化。模塊的粒度可大可小, 可以是系統,幾個子系統、某個服務,函數, 類,方法、 功能塊等等。

組件可以包括應用服務、資料庫、網路、物理機、還可以包括MQ、容器、Nginx等技術組件。

框架與架構

框架是組件實現的規範,例如:MVC、MVP、MVVM等,是提供基礎功能的產品,例如開源框架:Ruby on Rails、Spring、Laravel、Django等,這是可以拿來直接使用或者在此基礎上二次開發。

框架是規範,架構是結構。

架構重新定義

S君:架構是什麼?架構師解決什麼問題?

  • 架構是經過系統性地思考1, 權衡利弊之後在現有資源約束下的最合理決策, 最終明確的系統骨架2。包括子系統, 模塊, 組件. 以及他們之間協作關係3, 約束規範, 指導原則4。並由它來指導團隊中的每個人思想層面上的一致。

  • 架構師能力要求:理解業務,全局把控,選擇合適技術,解決關鍵問題、指導研發落地實施。

我在這重新定義架構:軟體架構指軟體系統的頂層結構。

架構是經過系統性地思考, 權衡利弊之後在現有資源約束下的最合理決策, 最終明確的系統骨架。包括子系統, 模塊, 組件. 以及他們之間協作關係, 約束規範, 指導原則。並由它來指導團隊中的每個人思想層面上的一致。涉及四方面:

  • 系統性思考的合理決策:比如技術選型、解決方案等。

  • 明確的系統骨架:明確系統有哪些部分組成。

  • 系統協作關係:各個組成部分如何協作來實現業務請求。

  • 約束規範和指導原則:保證系統有序,高效、穩定運行。

因此架構師具備能力:理解業務,全局把控,選擇合適技術,解決關鍵問題、指導研發落地實施。

架構的本質就是對系統進行有序化地重構以致符合當前業務的發展,並可以快速擴展。

那什麼樣的系統要考慮做架構設計 技術不會平白無故的出和自驅動發展起來,而架構的發展和需求是基於業務的驅動。

架構設計完全是為了業務:

  1. 需求相對複雜。
  2. 非功能性需求在整個系統占據重要位置。
  3. 系統生命周期長,有擴展性需求。
  4. 系統基於組件或者集成的需要。
  5. 業務流程再造的需要。

架構分層和分類

S君:

業務架構是戰略,應用架構是戰術,技術架構是裝備

  • 業務架構(俯視架構):包括業務規劃,業務模塊、業務流程,對整個系統的業務進行拆分,對領域模型進行設計,把現實的業務轉化成抽象對象。

  • 應用架構(剖面架構): 承接業務架構和技術架構。應用架構的本質是通過系統拆分,平衡業務和技術複雜性,保證系統形散神不散。
    應用作為獨立可部署的單元,為系統劃分了明確的邊界,深刻影響系統功能組織、代碼開發、部署和運維等各方面,應用架構定義系統有哪些應用、以及應用之間如何分工和合作。應用的分偏向於業務,反映業務架構,應用的合偏向於技術,影響技術架構。

  • 技術架構:確定組成應用系統的實際運行組件(技術選型),這些運行組件之間的關係,以及部署到硬體的策略。
    技術架構主要考慮系統的非功能性特征,對系統的高可用、高性能、擴展、安全、伸縮性、簡潔等做系統級的把握

  • 三者關係:
    業務架構是生產力,應用架構是生產關係,技術架構是生產工具。業務架構決定應用架構,應用架構需要適配業務架構,並隨著業務架構不斷進化,同時應用架構依托技術架構最終落地

補充材料:節選《軟體架構設計》 關註微信公眾號回覆【架構設計】獲取相關書籍

  • 架構五視圖:

  • 邏輯架構:邏輯架構關註功能,不僅包括用戶可見的功能,還包括為實現用戶功能而必須提供的“輔助功能模塊”。

  • 開發架構:開發架構關註程式包,不僅包括要編寫的源程式,還包括可以直接使用的第三方SDK 和現場框架、類庫,以及開發的系統將運行於其上的系統軟體或中間件。關註編譯時刻的靜態依賴關係。

  • 運行架構:運行架構關註進程、線程、對象等運行時概念,以及相關的併發,同步,通信等問題。運行架構關註運行期間各個單元的交互。

  • 物理架構:物理架構關註“目標程式及其依賴的運行庫和系統軟體”最終如何安裝或部署到物理機器,以及如何部署機器和網路來配合軟體系統的可靠性,可伸縮性等要求。

  • 數據架構:數據架構關註持久化數據的存儲方案,不僅包括實體及實體關係的存儲格式、還包括數據傳遞,數據複製,數據同步等策略。

架構分類可細分為業務架構、應用架構、技術架構, 代碼架構, 部署架構、數據架構

image

業務架構是戰略,應用架構是戰術,技術架構是裝備。其中應用架構承上啟下,一方面承接業務架構的落地,另一方面影響技術選型。

熟悉業務,形成業務架構,根據業務架構,做出相應的應用架構,最後技術架構落地實施。

如何針對當前需求,選擇合適的應用架構,如何面向未來,保證架構平滑過渡,這個是軟體開發者,特別是架構師,都需要深入思考的問題。

業務架構(俯視架構):

包括業務規劃,業務模塊、業務流程,對整個系統的業務進行拆分,對領域模型進行設計,把現實的業務轉化成抽象對象。

沒有最優的架構,只有最合適的架構,一切系統設計原則都要以解決業務問題為最終目標,脫離實際業務的技術情懷架構往往會給系統帶入大坑,任何不基於業務做異想天開的架構都是耍流氓。

所有問題的前提要搞清楚我們今天面臨的業務量有多大,增長走勢是什麼樣,而且解決高併發的過程,一定是一個循序漸進逐步的過程。合理的架構能夠提前預見業務發展1~2年為宜。這樣可以付出較為合理的代價換來真正達到技術引領業務成長的效果。

看看京東業務架構(網上分享圖):

image

應用架構(剖面架構,也叫邏輯架構圖):

硬體到應用的抽象,包括抽象層和編程介面。應用架構和業務架構是相輔相成的關係。業務架構的每一部分都有應用架構。

類似:

image

應用架構:應用作為獨立可部署的單元,為系統劃分了明確的邊界,深刻影響系統功能組織、代碼開發、部署和運維等各方面. 應用架構定義系統有哪些應用、以及應用之間如何分工和合作。這裡所謂應用就是各個邏輯模塊或者子系統。

應用架構圖關鍵有2點:

①. 職責劃分: 明確應用(各個邏輯模塊或者子系統)邊界

  • 邏輯分層

  • 子系統、模塊定義

  • 關鍵類

②. 職責之間的協作:

  • 介面協議:應用對外輸出的介面。
  • 協作關係:應用之間的調用關係。

應用分層有兩種方式:

一種是水平分(橫向),按照功能處理順序劃分應用,比如把系統分為web前端/中間服務/後臺任務,這是面向業務深度的劃分。

另一種是垂直分(縱向),按照不同的業務類型劃分應用,比如進銷存系統可以劃分為三個獨立的應用,這是面向業務廣度的劃分。

應用的反映應用之間如何協作,共同完成複雜的業務case,主要體現在應用之間的通訊機制和數據格式,通訊機制可以是同步調用/非同步消息/共用DB訪問等,數據格式可以是文本/XML/JSON/二進位等。

應用的分偏向於業務,反映業務架構,應用的合偏向於技術,影響技術架構。分降低了業務複雜度,系統更有序,合增加了技術複雜度,系統更無序。

應用架構的本質是通過系統拆分,平衡業務和技術複雜性,保證系統形散神不散。

系統採用什麼樣的應用架構,受業務複雜性影響,包括企業發展階段和業務特點;同時受技術複雜性影響,包括IT技術發展階段和內部技術人員水平。業務複雜性(包括業務量大)必然帶來技術複雜性,應用架構目標是解決業務複雜性的同時,避免技術太複雜,確保業務架構落地。

數據架構

數據架構指導資料庫的設計. 不僅僅要考慮開發中涉及到的資料庫,實體模型,也要考慮物理架構中數據存儲的設計。

image

代碼架構(也叫開發架構):

子系統代碼架構主要為開發人員提供切實可行的指導,如果代碼架構設計不足,就會造成影響全局的架構設計。比如公司內不同的開發團隊使用不同的技術棧或者組件,結果公司整體架構設計就會失控。

代碼架構主要定義:

①. 代碼單元:

  • 配置設計

  • 框架、類庫。

②. 代碼單元組織:

  • 編碼規範,編碼的慣例。

  • 項目模塊劃分

  • 頂層文件結構設計,比如mvc設計。

  • 依賴關係

image

技術架構

技術架構:確定組成應用系統的實際運行組件(lvs,nginx,tomcat,php-fpm等),這些運行組件之間的關係,以及部署到硬體的策略。

技術架構主要考慮系統的非功能性特征,對系統的高可用、高性能、擴展、安全、伸縮性、簡潔等做系統級的把握。

系統架構的設計要求架構師具備軟體和硬體的功能和性能的過硬知識,這也是架構設計工作中最為困難的工作。

部署拓撲架構圖(實際物理架構圖):

拓撲架構,包括架構部署了幾個節點,節點之間的關係,伺服器的高可用,網路介面和協議等,決定了應用如何運行,運行的性能,可維護性,可擴展性,是所有架構的基礎。這個圖主要是運維工程師主要關註的對象。

image

物理架構主要考慮硬體選擇和拓撲結構,軟體到硬體的映射,軟硬體的相互影響。

image

架構級別

S君:

  • 戰略設計即業務架構設計
  • 戰術設計即應用架構設計
  • 戰術實施即技術架構實施

我們使用金字塔的架構級別來說明,上層級別包含下層:

image

  • 系統級:即整個系統內各部分的關係以及如何治理:分層
  • 應用級:即單個應用的整體架構,及其與系統內單個應用的關係等。
  • 模塊級:即應用內部的模塊架構,如代碼的模塊化、數據和狀態的管理等。
  • 代碼級:即從代碼級別保障架構實施。

戰略設計與戰術設計

基於架構金字塔,我們有了系統架構的戰略設計與戰術設計的完美結合:

  • 戰略設計:業務架構用於指導架構師如何進行系統架構設計。
  • 戰術設計:應用架構要根據業務架構來設計。
  • 戰術實施:應用架構確定以後,就是技術選型。

image

應用架構演進

S君

應用架構演化過程:單體應用-> 服務化 -> 微服務

業務架構是生產力,應用架構是生產關係,技術架構是生產工具。業務架構決定應用架構,應用架構需要適配業務架構,並隨著業務架構不斷進化,同時應用架構依托技術架構最終落地。

架構演進路程:單體應用→分散式應用服務化→微服務

單體應用

企業一開始業務比較簡單,只應用某個簡單場景,應用服務支持數據增刪改查和簡單的邏輯即可,單體應用可以滿足要求。

典型的三級架構,前端(Web/手機端)+中間業務邏輯層+資料庫層。這是一種典型的Java Spring MVC或者Python Django框架的應用。其架構圖如下所示:

image

針對單體應用,非功能性需求的做法:

  • 性能需求:使用緩存改善性能

  • 併發需求:使用集群改善併發

  • 讀寫分離:資料庫地讀寫分離

  • 使用反向代理和cdn加速、

  • 使用分散式文件和分散式資料庫

單體架構的應用比較容易部署、測試, 在項目的初期,單體應用可以很好地運行。然而,隨著需求的不斷增加, 越來越多的人加入開發團隊,代碼庫也在飛速地膨脹。慢慢地,單體應用變得越來越臃腫,可維護性、靈活性逐漸降低,維護成本越來越高。下麵是單體架構應用的一些缺點:

  • 複雜性高:以一個百萬行級別的單體應用為例,整個項目包含的模塊非常多、模塊的邊界模糊、 依賴關係不清晰、 代碼質量參差不齊、 混亂地堆砌在一起。可想而知整個項目非常複雜。每次修改代碼都心驚膽戰, 甚至添加一個簡單的功能, 或者修改一個Bug都會帶來隱含的缺陷。

  • 技術債務:隨著時間推移、需求變更和人員更迭,會逐漸形成應用程式的技術債務, 並且越積 越多。“ 不壞不修”, 這在軟體開發中非常常見, 在單體應用中這種思想更甚。已使用的系統設計或代碼難以被修改,因為應用程式中的其他模塊可能會以意料之外的方式使用它。

  • 部署頻率低:隨著代碼的增多,構建和部署的時間也會增加。而在單體應用中, 每次功能的變更或缺陷的修複都會導致需要重新部署整個應用。全量部署的方式耗時長、 影響範圍大、 風險高, 這使得單體應用項目上線部署的頻率較低。而部署頻率低又導致兩次發佈之間會有大量的功能變更和缺陷修複,出錯率比較高。

  • 可靠性差:某個應用Bug,例如死迴圈、記憶體溢出等, 可能會導致整個應用的崩潰。
    擴展能力受限:單體應用只能作為一個整體進行擴展,無法根據業務模塊的需要進行伸縮。例如,應用中有的模塊是計算密集型的,它需要強勁的CPU;有的模塊則是IO密集型的,需要更大的記憶體。由於這些模塊部署在一起,不得不在硬體的選擇上做出妥協。

  • 阻礙技術創新:單體應用往往使用統一的技術平臺或方案解決所有的問題, 團隊中的每個成員 都必須使用相同的開發語言和框架,要想引入新框架或新技術平臺會非常困難。

分散式

隨著業務深入,業務要求的產品功能越來越多,每個業務模塊邏輯也都變得更加複雜,業務的深度和廣度都增加,使得單體應用變得越來越臃腫,可維護性、靈活性逐漸降低,增加新功能開發周期越來越長,維護成本越來越高。

這時需要對系統按照業務功能模塊拆分,將各個模塊服務化,變成一個分散式系統。業務模塊分別部署在不同的伺服器上,各個業務模塊之間通過介面進行數據交互。

該架構相對於單體架構來說,這種架構提供了負載均衡的能力,大大提高了系統負載能力,解決了網站高併發的需求。另外還有以下特點:

  • 降低了耦合度:把模塊拆分,使用介面通信,降低模塊之間的耦合度。
  • 責任清晰:把項目拆分成若幹個子項目,不同的團隊負責不同的子項目。
  • 擴展方便:增加功能時只需要再增加一個子項目,調用其他系統的介面就可以。
  • 部署方便:可以靈活的進行分散式部署。
  • 提高代碼的復用性:比如Service層,如果不採用分散式rest服務方式架構就會在手機Wap商城,微信商城,PC,Android,iOS每個端都要寫一個Service層邏輯,開發量大,難以維護一起升級,這時候就可以採用分散式rest服務方式,公用一個service層。

缺點:系統之間的交互要使用遠程通信,介面開發增大工作量,但是利大於弊。

微服務

緊接著業務模式越來越複雜,訂單、商品、庫存、價格等各個模塊都很深入,比如價格區分會員等級,訪問渠道(app還是PC),銷售方式(團購還是普通)等,還有大量的價格促銷,這些規則很複雜,容易相互衝突,需要把分散到各個業務的價格邏輯進行統一管理,以基礎價格服務的方式透明地提供給上層應用,變成一個微內核的服務化架構,即微服務。

微服務的特點:

  • 易於開發和維護:一個微服務只會關註一個特定的業務功能,所以它業務清晰、代碼量較少。開發和維護單個微服務相對簡單。而整個應用是由若幹個微服務構建而成的,所以整個應用也會被維持在一個可控狀態。

  • 單個微服務啟動較快:單個微服務代碼量較少, 所以啟動會比較快。

  • 局部修改容易部署:單體應用只要有修改,就得重新部署整個應用,微服務解決了這樣的問題。一般來說,對某個微服務進行修改,只需要重新部署這個服務即可。

  • 技術棧不受限:在微服務架構中,可以結合項目業務及團隊的特點,合理地選擇技術棧。例如某些服務可使用關係型資料庫MySQL;某些微服務有圖形計算的需求,可以使用Neo4j;甚至可根據需要,部分微服務使用Java開發,部分微服務使用Node.js開發。

微服務雖然有很多吸引人的地方,但它並不是免費的午餐,使用它是有代價的。使用微服務架構面臨的挑戰。

  • 運維要求較高:更多的服務意味著更多的運維投入。在單體架構中,只需要保證一個應用的正常運行。而在微服務中,需要保證幾十甚至幾百個服務服務的正常運行與協作,這給運維帶來了很大的挑戰。

  • 分散式固有的複雜性:使用微服務構建的是分散式系統。對於一個分散式系統,系統容錯、網路延遲、分散式事務等都會帶來巨大的挑戰。

  • 介面調整成本高:微服務之間通過介面進行通信。如果修改某一個微服務的API,可能所有使用了該介面的微服務都需要做調整。

  • 重覆勞動:很多服務可能都會使用到相同的功能,而這個功能並沒有達到分解為一個微服務的程度,這個時候,可能各個服務都會開發這一功能,從而導致代碼重覆。儘管可以使用共用庫來解決這個問題(例如可以將這個功能封裝成公共組件,需要該功能的微服務引用該組件),但共用庫在多語言環境下就不一定行得通了。

衡量架構的合理性

架構為業務服務,沒有最優的架構,只有最合適的架構,架構始終以高效,穩定,安全為目標來衡量其合理性。

合理的架構設計:

業務需求角度

  • 能解決當下業務需求和問題

  • 高效完成業務需求: 能以優雅且可復用的方式解決當下所有業務問題

  • 前瞻性設計: 能在未來一段時間都能以第2種方式滿足業務,從而不會每次當業務進行演變時,導致架構翻天覆地的變化。

非業務需求角度

①. 穩定性指標:

高可用:要儘可能的提高軟體的可用性,我想每個操作人都不願意看到自己的工作無法正常進行。黑盒白盒測試、單元測試、自動化測試、故障註入測試、提高測試覆蓋率等方式來一步一步推進。

②. 高效指標:

文檔化:不管是整體還是部分的整個生命周期內都必須做好文檔化,變動的來源包括但不限於BUG,需求。

可擴展:軟體的設計秉承著低耦合的理念去做,註意在合理的地方抽象。方便功能更改、新增和運用技術的迭代,並且支持在適時對架構做出重構。

高復用:為了避免重覆勞動,為了降低成本,我們希望能夠重用之前的代碼、之前的設計。這點對於架構環境的依賴是最大的。

③. 安全指標

安全:組織的運作過程中產生的數據都是具有商業價值的,保證數據的安全也是刻不容緩的一部分。以免出現XX門之類醜聞。加密、https等為普遍手段

常見架構誤區

S君:

架構設計需要考慮功能需求和非功能需求,要根據現狀又要有一定的前瞻性,也講究方法又要講究落地,要循序漸進,不斷演化

  • 低開高走落不到實處
  • 遺漏關鍵性約束與非功能需求
  • 為虛無的未來買單而過度設計
  • 過早做出關鍵性決策
  • 客戶說啥就是啥成為傳話筒
  • 埋頭幹活兒缺乏前瞻性
  • 架構設計還要考慮系統可測性
  • 架構設計不要企圖一步到位

常見誤區:

  • 誤區1——架構專門由架構師來做,業務開發人員無需關註。架構的再好,最終還是需要代碼來落地,並且組織越大這個落地的難度越大。不單單是系統架構,每個解決方案每個項目也由自己的架構,如分層、設計模式等。如果每一塊磚瓦不夠堅固,那麼整個系統還是會由崩塌的風險。所謂“千里之堤,潰於蟻穴”。

  • 誤區2——架構師確定了架構藍圖之後任務就結束了。架構不是“空中樓閣”,最終還是要落地的,但是架構師完全不去深入到第一線怎麼知道“地”在哪?怎麼才能落的穩穩噹噹。

  • 誤區3——不做出完美的架構設計不開工。世上沒有最好架構,只有最合適的架構,不要企圖一步到位。我們需要的不是一下子造出一輛汽車,而是從單輪車→自行車→摩托車,最後再到汽車。想象一下2年後才能造出的產品,當初市場還存在嗎?

  • 誤區4—— 為虛無的未來埋單而過度設計。在創業公司初期,業務場景和需求邊界很難把握,產品需要快速迭代和變現,需求頻繁更新,這個時候需要的是快速實現。不要過多考慮未來的擴展,說不定功能做完,效果不好就無用了。如果業務模式和應用場景邊界都已經比較清晰,是應該適當的考慮未來的擴展性設計。

  • 誤區5——一味追隨大公司的解決方案:由於大公司巨大成功的光環效應,再加上從大公司挖來的技術高手的影響,網站在討論架構決策時,最有說服力的一句話就成了“淘寶就是這麼搞的”或者“騰訊 就是這麼搞的”。大公司的經驗和成功模式固然重要,值得學習借鑒,但如果因此而變得盲從,就失去了堅持自我的勇氣,在架構演化的道路上遲早會迷路。

  • 誤區6——為了技術而技術:技術是為業務而存在的,除此毫無意義。在技術選型和架構設計中,脫離網站業務發展的實際,一味追求時髦的新技術,可能會將技術發展引入崎嶇小道,架構之路越走越難。考慮實現成本、時間、人員等各方面都要綜合考慮,理想與現實需要折中。

架構知識體系

架構演進

  • 初始階段:LAMP,部署在一臺伺服器
  • 應用伺服器和數據伺服器分離
  • 使用緩存改善性能
  • 使用集群改善併發
  • 資料庫地讀寫分離
  • 使用反向代理和cdn加速
  • 使用分散式文件和分散式資料庫
  • 業務拆分
  • 分散式服務

架構模式

分層:橫向分層:應用層,服務層,數據層

分割:縱向分割:拆分功能和服務

分散式

  • 分散式應用和服務
  • 分散式靜態資源
  • 分散式數據和存儲
  • 分散式計算

集群:提高併發和可用性

緩存:優化系統性能

  • cdn
  • 方向代理訪問資源
  • 本地緩存
  • 分散式緩存

非同步:降低系統的耦合性

  • 提供系統的可用性
  • 加快響應速度

冗餘:冷備和熱備,保證系統的可用性

自動化:發佈,測試,部署,監控,報警,失效轉移,故障恢復

安全:

架構核心要素

高性能:網站的靈魂

  • 性能測試
  • 前端優化
  • 應用優化
  • 資料庫優化

可用性:保證伺服器不宕機,一般通過冗餘部署備份伺服器來完成

  • 負載均衡
  • 數據備份
  • 自動發佈
  • 灰度發佈
  • 監控報警

伸縮性:建集群,是否快速應對大規模增長的流量,容易添加新的機器

  • 集群
  • 負載均衡
  • 緩存負載均衡(冷熱)

可擴展性:主要關註功能需求,應對業務的擴展,快速響應業務的變化。是否做法開閉原則,系統耦合依賴

  • 分散式消息
  • 服務化

安全性:網站的各種攻擊,各種漏洞是否堵住,架構是否可以做到限流作用,防止ddos攻擊。

  • xss攻擊
  • sql註入
  • csr攻擊
  • web防火牆漏洞
  • 安全漏洞
  • ssl

架構書籍推薦

  1. 《大型網站技術架構:核心原理與案例分析》

這是比較早,比較系統介紹大型網站技術架構的書,通俗易懂又充滿智慧,即便你之前完全沒接觸過網站開發,通讀前幾章,也能快速獲取到常見的網站技術架構及其應用場景。非常贊。

  1. 《億級流量網站架構核心技術》

相比《大型網站技術架構》的高屋建瓴,開濤的這本《億級流量網站架構核心技術》則落實到細節,網站架構中常見的各種技術,比如緩存、隊列、線程池、代理……,統統都講到了,而且配有核心代碼。甚至連 Nginx 的配置都有!

如果你想在實現大流量網站時找參考技術和代碼,這本書最合適啦。

  1. 《架構即未來》

這是一本“神書”啦,超越具體技術層面,著重剖析架構問題的根源,幫助我們弄清楚應該以何種方式管理、領導、組織和配置團隊。

  1. 《分散式服務架構:原理、設計與實戰》

這本書全面介紹了分散式服務架構的原理與設計,並結合作者在實施微服務架構過程中的實踐經驗,總結了保障線上服務健康、可靠的最佳方案,是一本架構級、實戰型的重量級著作。

  1. 《聊聊架構》

這算是架構方面的一本神書了,從架構的原初談起,從業務的拆分談起,談到架構的目的,架構師的角色,架構師如何將架構落地……強烈推薦。

不過,對於沒有架構實踐經驗的小伙伴來講,可能會覺得這本書比較虛,概念多,實戰少。但如果你有過一兩個項目的架構經驗,就會深深認同書中追本溯源探討的架構理念。

  1. 《軟體架構師的12項修煉》

大多數時候所謂的“技術之玻璃天花板”其實只是缺乏軟技能而已。這些技能可以學到,缺乏的知識可以通過決定改變的努力來彌補。

參考:

什麼是架構設計?架構設計看這篇文章就夠了

Redis為什麼這麼快?

重磅:解讀2020年最新JVM生態報告

BIO,NIO,AIO 總結

JDK8的新特性,你知道多少?

回覆“資料”,免費獲取 一份獨家嘔心整理的技術資料! image


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、環境搭建 基於node.js的http-server伺服器搭建 https://www.npmjs.com/package/http-server cnpm install http-server -g 2、首頁實現 創建一個目錄,叫webapp,在裡面創建一個index.html 打開cmd, ...
  • 利用EasyUI的TreeGrid組件格式化顯示Json數據,首先讀入Json文件,轉成Map對象,迴圈遞歸每一個Map,判斷它的值是基本類型還是Map。如果基本類型,則是屬性節點。如果Map,則是對象,需要再遍歷。 1.Map解析Tree對象 Tree對象 public class Display ...
  • JS 排序演算法之計數和基數排序 [Toc] 計數排序 利用數組的index是天然有序的特征來排序. 例如: 已知一個亂序數組的範圍是0~10,長度未知, 我們只需要遍歷一遍數組,點出每個值出現的次數,並用一個新數組來存儲這個次數,就能做到排序. 假如數字1出現3次, 那麼新數組newAry[1]=3 ...
  • JavaScript 如何複製一個對象?淺拷貝可以複製出原始值屬性,但是對於引用值屬性僅僅複製了一份引用。利用遞歸對每個引用值屬性的屬性進行複製,這種方式稱之為深拷貝 ...
  • 1 完整代碼下載 https://pan.baidu.com/s/1JJyVcP2KqXsd5G6eaYpgHQ 提取碼 3fzt (壓縮包名: 2020-3-20-demo.zip) 2 圖片展示 3 主要代碼 1 /** HandCreate 簡單的 圖形界面 搭建幾何體 2 construct ...
  • 開篇 在一門編程語言中,往往會提供大量的運算符。按功能來分的話,有算術運算符、賦值運算符、關係運算符、邏輯運算符、位運算符等。這些對於大家來說都不陌生。但是,本期的主角『位運算』符相對而言是比較少去使用的。因為位運算符主要針對兩個二進位數進行位運算。 巧用位運算能極大的精簡代碼和提高程式效率。所以, ...
  • 圖解Java設計模式之裝飾者模式 星巴克咖啡訂單項目(咖啡館) 方案 1 - 解決星巴克咖啡訂單項目 方案1 - 解決星巴克咖啡訂單問題分析 方案 2 - 解決星巴克咖啡訂單(好點) 方案2 - 解決星巴克咖啡訂單問題分析 裝飾者模式定義 裝飾者模式原理 裝飾者模式解決星巴克咖啡訂單 裝飾者模式下的 ...
  • 此項目為Springboot工作流版本 windows 風格,瀏覽器訪問操作使用,非桌面應用程式。 1.代碼生成器: [正反雙向](單表、主表、明細表、樹形表,快速開發利器) freemaker模版技術 ,0個代碼不用寫,生成完整的一個模塊,帶頁面、建表sql腳本、處理類、service等完整模塊 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...