Java分佈式架構的演進過程

一.分佈式架構的發展歷史mysql

1946年,世界上第一臺電子計算機在美國的賓夕法尼亞大學誕生,它的名字是:ENICAC ,這臺計算機的體重比較大,計算速度也不快,可是而表明了計算機時代的到來,再之後的互聯網的發展中也有基礎性的意義。web

計算機的組成是有五部分完成的,分別是:輸入設備,輸出設備,存儲器,存儲器裏面由運算器和控制器,有一個馮諾依曼的模型很是形象的對象計算機的組成進行了描述,不過計算機也是有數據流,指令流,控制流來進行計算的和正常運轉的。如圖:redis

Java分佈式架構的演進過程

ENIAC以後,電子計算機進入到了IBM主導的大型機的時代, 在1946年第一臺IBM大型機SYSTEM/360誕生,這使得IBM在20世紀50~60年代統治了整個大型計算機的工業,在大型主機時代,計算機架構向兩個方向發展CISC(微處理器執行的計算機語言指令集)CPU爲架構的價格便宜的我的PC和RISC(精簡指令集計算機)價格高的小型UNIX服務器。sql

大型主機的出現,憑藉着計算能力和處理能力,高的穩定性和安全性,在很長的一段時間內引領到計算領域的發展。可是集中式的計算機系統來帶來了一些問題,來愈來愈不能知足用戶的需求好比說:mongodb

1.大型的主機很是貴,通常的小企業用不起。數據庫

2.大型主機比較複雜,培養人才的成本比較高。緩存

3.單點問題,如過大型機出現故障,整個系統都掛了運行不了,使企業的損失很是大。安全

4.隨着技術的進步,我的PC電腦的性能愈來愈高,成本也愈來愈低。服務器

阿里巴巴在2009年發起了一項去「IOE」的驅動session

IOE指的是IBM的小型機,Oracle的數據庫和EMC的高端存儲設備,2009年的去IOE的運動,一直到2003的支付寶的最後一臺IBM的小型機的下線。

爲何要去IOE

阿里巴巴過去數據庫使用的是Oracle,並使用小型機和高端存儲設備提供高性能的數據處理和存儲服務。隨着公司的業務量的上升,用戶規模的不斷上漲,傳統的集中式的架構Oracle數據庫在擴展方面遭遇了瓶頸。向傳統的Oracle,DB2都是以集中式的爲主,存在的缺點就是擴展性的不足,集中式的擴展主要是採用的是向上的擴展不是水平的擴展,這樣時間長了,遲早都會遇到系統瓶頸。

一.分佈式架構的常見概念

集羣

小飯店原來是一個廚師,切菜洗菜備料炒菜全乾。後來客人多了,廚房一個廚師忙不過來,又請了個廚師,兩個廚師都能炒同樣的菜,這兩個廚師的關係就是集羣。

Java分佈式架構的演進過程

分佈式

爲了讓廚師專心炒菜,把菜作到極致,又請了個配菜師負責切菜,備菜,備料,廚師和配菜師的關係就是分佈式的,一個配菜師也忙不過來,有請了個配菜師,這兩個配菜師的關係就是集羣了。因此說有分佈式的架構中可能有集羣,但集羣不等於有分佈式。

Java分佈式架構的演進過程

節點

節點是指一個能夠獨立按照分佈式協議完成一組邏輯的程序個體。在具體的項目中,一個節點表示的是一個操做系統上的進程。

副本機制

副本指的是在分佈式系統中爲數據或服務提供冗餘。

數據副本指在不一樣的節點上持久化同一份數據,當出現某一個節點的數據丟失時,能夠從副本讀取數據。數據副本是分佈式系統中結果數據丟失的惟一手段。

服務副本表示的是多個節點提供相同的服務,經過主從關係來實現服務的高可用方案。

中間件

中間件位與操做系統提供的服務以外,又不屬於應用,它是位與應用和系統層之間爲開發者方便的處理通訊,輸入和輸出的一類軟件,可以讓用戶關心本身應用的一部分。

架構的發展過程

一個成熟的大型網站系統架構並非一開始就設計的很是完美的,也不是一開始就具有高性能,高可用,安全性等特性,而是隨着用戶量的增長,業務功能的擴展慢慢完善演變過來的。在這個發展過程當中,開發模式,技術架構等都會發生很是大的變化。

假如系統具有一下功能:

用戶模塊:用戶註冊和管理

商品模塊:商品展現和管理

交易模塊:建立交易及支付結算

階段一:單應用架構

系統的初級都是應用和數據庫都放在一臺服務器上。

Java分佈式架構的演進過程

階段二:應用服務器和數據庫服務器分離

隨着網站的用戶量增大,流量增大,對應用服務器和數據庫服務器單獨的部署機器,這樣能夠增長系統的性能,提升訪問的效率,提升單機的負載能力和容災的能力。

階段三:應用服務器集羣-應用服務器負載告警

隨着訪問量和流量的增長,假設數據庫沒有遇到瓶頸,對應用服務器集羣來對請求進行分流,提升程序的性能。存在的問題:用戶的請求由誰來轉發,session如何來管理的問題。

Java分佈式架構的演進過程

階段四:數據庫壓力變大-數據庫讀寫分離

讀寫分離的話,這樣之後的請求,查詢的請求就能夠去從庫裏面讀數據,寫的數據能夠到主庫中了,可是會帶來幾個問題:

1.主從的數據庫之間的數據同步:可使用mysql自帶的master-slave方式實現主從複製

2.對應的數據源的選擇:採用第三方數據庫中間件,例如:mycat

Java分佈式架構的演進過程

階段五:使用搜索引擎緩解讀庫的壓力

數據庫作讀庫的話,經常對模糊查詢的性能不是很好,特別是對於大型的互聯網公司來講,想搜索的模塊就比較核心了,這是可使用搜索引擎了,雖然能夠大幅度的提升查詢的速度,可是同時也會帶來一些問題好比索引的構建。

Java分佈式架構的演進過程

階段六:引入緩存機制緩解數據庫的壓力

對一些熱點的數據,可使用redis,memcache來做爲應用層的緩存;另外在某些場景下,可使用mongodb來替代關係型數據庫來存儲。

階段七:數據庫的水平/垂直拆分

垂直拆分:把數據庫中不一樣的業務數據拆分到不一樣的數據庫中。

水平拆分:把同一個表中的數據拆分到兩個甚至更多的數據庫中,水平拆分的緣由是某些業務量數據量大的已經達到了單個數據庫的瓶頸,這時候能夠採起將表拆分到多個數據庫中。

Java分佈式架構的演進過程

階段八:應用的拆分

隨着業務的發展,業務愈來愈多,應用的壓力愈來愈大。工程規模也愈來愈龐大。這個時候就能夠考慮將應用拆分,按照領域模型將咱們的用戶,商品,交易分拆成子系統。

Java分佈式架構的演進過程

這樣拆分之後,可能會有一些相同的代碼,好比用戶操做,商品的交易查詢,全部會致使每一個系統都會有用戶查詢和訪問相關的操做。這些相同的代碼和模塊必定要抽象出來。這樣有利於維護和管理。

Java分佈式架構的演進過程

服務拆分之後,服務之間的通訊能夠經過RPC技術,比較典型的有:webservice、hession、http、RMI等。

相關文章
相關標籤/搜索