分布式基础理论
分布式系統(tǒng)是建立在網(wǎng)絡(luò)之上的軟件系統(tǒng),分布式系統(tǒng)具有高度的內(nèi)聚性和透明性。
內(nèi)聚性是指每一個數(shù)據(jù)庫分布節(jié)點高度自治,有本地的數(shù)據(jù)庫管理系統(tǒng)。透明性是指每一個數(shù)據(jù)庫分布節(jié)點對用戶的應(yīng)用來說都是透明的,看不出是本地還是遠程。
分布式系統(tǒng)是多個處理機通過通信線路互聯(lián)而構(gòu)成的松散耦合的系統(tǒng)。分布式系統(tǒng)應(yīng)具有以下四個特征: ?
(1)分布性。分布式系統(tǒng)由多臺計算機組成,它們在地域上是分散的。整個系統(tǒng)的功能是分散在各個節(jié)點上實現(xiàn)的,因而分布式系統(tǒng)具有數(shù)據(jù)處理的分布性。
(2)自治性。分布式系統(tǒng)中的各個節(jié)點都包含自己的處理機和內(nèi)存,各自具有獨立的處理數(shù)據(jù)的功能。
(3)并行性。一個大的任務(wù)可以劃分為若干個子任務(wù),分別在不同的主機上執(zhí)行。
(4)全局性。分布式系統(tǒng)中必須存在一個單一的、全局的進程通信機制,使得任何一個進程都能與其他進程通信,并且不區(qū)分本地通信與遠程通信。同時,還應(yīng)當(dāng)有全局的保護機制。系統(tǒng)中所有機器上有統(tǒng)一的系統(tǒng)調(diào)用集合,它們必須適應(yīng)分布式的環(huán)境。在所有CPU上運行同樣的內(nèi)核,使協(xié)調(diào)工作更加容易
優(yōu)點
(1)資源共享。若干不同的節(jié)點通過通信網(wǎng)絡(luò)彼此互聯(lián),一個節(jié)點上的用戶可以使用其他節(jié)點上的資源
(2)加快計算速度。如果一個特定的計算任務(wù)可以劃分為若干個并行運行的子任務(wù),則可把這些子任務(wù)分散到不同的節(jié)點上,使它們同時在這些節(jié)點上運行,從而加快計算速度。另外,分布式系統(tǒng)具有計算遷移功能,如果某個節(jié)點上的負載太重,則可把其中一些作業(yè)移到其他節(jié)點去執(zhí)行,從而減輕該節(jié)點的負載。這種作業(yè)遷移稱為負載平衡。 ?
(3)可靠性高。分布式系統(tǒng)具有高可靠性。如果其中某個節(jié)點失效了,則其余的節(jié)點可以繼續(xù)操作,整個系統(tǒng)不會因為一個或少數(shù)幾個節(jié)點的故障而全體崩潰。因此,分布式系統(tǒng)有很好的容錯性能。系統(tǒng)必須能夠檢測節(jié)點的故障,采取適當(dāng)?shù)氖侄?#xff0c;使它從故障中恢復(fù)過來。
(4)通信方便、快捷。分布式系統(tǒng)中各個節(jié)點通過一個通信網(wǎng)絡(luò)互聯(lián)在一起。通信網(wǎng)絡(luò)由通信線路、調(diào)制解調(diào)器和通信處理器等組成,不同節(jié)點的用戶可以方便地交換信息。缺點
存在通信網(wǎng)絡(luò)飽和或信息丟失和網(wǎng)絡(luò)安全問題,方便的數(shù)據(jù)共享同時意味著機密數(shù)據(jù)容易被竊取
系統(tǒng)設(shè)計難點編輯?
1.部分失效問題
由于分布式系統(tǒng)通常由若干部分組成,各個部分由于各種原因可能發(fā)生故障,如硬件故障、軟件錯誤及錯誤操作等。如果一個分布式系統(tǒng)不對這些故障進行有效的處理,系統(tǒng)某一組成部分的故障可能導(dǎo)致整個系統(tǒng)的癱瘓。 ?
2.性能和可靠性過分依賴于網(wǎng)絡(luò)
由于分布式系統(tǒng)是建立在網(wǎng)絡(luò)之上的,而網(wǎng)絡(luò)本身是不可靠的,可能經(jīng)常發(fā)生故障,網(wǎng)絡(luò)故障可能導(dǎo)致系統(tǒng)服務(wù)的終止。另外,網(wǎng)絡(luò)超負荷會導(dǎo)致性能的降低,增加系統(tǒng)的響應(yīng)時間。
3.缺乏統(tǒng)一控制
一個分布式系統(tǒng)的控制通常是一個典型的分散控制,沒有統(tǒng)一的中心控制。因此,分布式系統(tǒng)通常需要相應(yīng)的同步機制宋協(xié)調(diào)系統(tǒng)中各個部分的工作。設(shè)計與實現(xiàn)一個對用戶來說是透明的且具有容錯能力的分布式系統(tǒng)是一項具有挑戰(zhàn)性的工作。?
4.難以合理設(shè)計資源分配策略
在集中式系統(tǒng)中,所有的資源都由操作系統(tǒng)管理和分配,但在分布式系統(tǒng)中,資源屬于各節(jié)點,所以調(diào)度的靈活性不如集中式系統(tǒng),資源的物理分布可能與用戶請求的分布不匹配,某些資源可能空閑,而另一些資源可能超載。 ?
5.安全保密性問題
開放性使得分布式系統(tǒng)中的許多軟件接口都提供給用戶,這樣的開放式結(jié)構(gòu)對于開發(fā)人員非常有價值,但同時也為破壞者打開了方便之門。
使用分布式系統(tǒng)主要有:
1.增大系統(tǒng)容量。我們的業(yè)務(wù)量越來越大,而要能應(yīng)對越來越大的業(yè)務(wù)量,一臺機器的性能已經(jīng)無法滿足了,我們需要多臺機器才能應(yīng)對大規(guī)模的應(yīng)用場景。所以,我們需要垂直或是水平拆分業(yè)務(wù)系統(tǒng),讓其變成一個分布式的架構(gòu)。
2.加強系統(tǒng)可用。我們的業(yè)務(wù)越來越關(guān)鍵,需要提高整個系統(tǒng)架構(gòu)的可用性,這就意味著架構(gòu)中不能存在單點故障。這樣,整個系統(tǒng)不會因為一臺機器出故障而導(dǎo)致整體不可用。所以,需要通過分布式架構(gòu)來冗余系統(tǒng)以消除單點故障,從而提高系統(tǒng)的可用性。
3.因為模塊化,所以系統(tǒng)模塊重用度更高
4.因為軟件服務(wù)模塊被拆分,開發(fā)和發(fā)布速度可以并行而變得更快
5.系統(tǒng)擴展性更高
6.團隊協(xié)作流程也會得到改善
?
分布式系統(tǒng)的類型有三種:
1.分布式處理,但只有一個總數(shù)據(jù)庫,沒有局部數(shù)據(jù)庫
2.分層式處理,每一層都有自己的數(shù)據(jù)庫
3.充分分散的分布式網(wǎng)絡(luò),沒有中央控制部分,各節(jié)點之間的聯(lián)系方式又可以有多種,如松散的聯(lián)接,緊密的聯(lián)接,動態(tài)的聯(lián)接,廣播通知式的聯(lián)接等
?
?
什么是分布式系統(tǒng)!以及分布式系統(tǒng)架構(gòu)的優(yōu)缺點
1.從上面的表格可以看到,分布式系統(tǒng)雖然有一些優(yōu)勢,但也存在一些問題
2.架構(gòu)設(shè)計變得復(fù)雜(尤其是其中的分布式事務(wù))
3.部署單個服務(wù)會比較快,但是如果一次部署需要多個服務(wù),部署會變得復(fù)雜
4.系統(tǒng)的吞吐量會變大,但是響應(yīng)時間會變長
5.運維復(fù)雜度會因為服務(wù)變多而變得很復(fù)雜
6.架構(gòu)復(fù)雜導(dǎo)致學(xué)習(xí)曲線變大
7.測試和查錯的復(fù)雜度增大
8.技術(shù)可以很多樣,這會帶來維護和運維的復(fù)雜度
9.管理分布式系統(tǒng)中的服務(wù)和調(diào)度變得困難和復(fù)雜
?
?
總結(jié)
- 上一篇: 常见设计模式说明
- 下一篇: 创建守护进程关键步骤