千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關(guān)注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  應聘面試  >  Python面試題  > 數(shù)據(jù)庫負載均衡

數(shù)據(jù)庫負載均衡

來源:千鋒教育
發(fā)布人:wjy
時間: 2022-08-22 14:36:04 1661150164

負載均衡集群是由一組相互獨立的計算機系統(tǒng)構(gòu)成,通過常規(guī)網(wǎng)絡或?qū)S镁W(wǎng)絡進行連接,由路由器銜接在一起,各節(jié)點相互協(xié)作、共同負載、均衡壓力,對客戶端來說,整個群集可以視為一臺具有超高性能的獨立服務器。

數(shù)據(jù)庫負載均衡

1、實現(xiàn)原理實現(xiàn)數(shù)據(jù)庫的負載均衡技術(shù),首先要有一個可以控制連接數(shù)據(jù)庫的控制端。在這里,它截斷了數(shù)據(jù)庫和程序的直接連接,由所有的程序來訪問這個中間層,然后再由中間層來訪問數(shù)據(jù)庫。

這樣, 我們就可以具體控制訪問某個數(shù)據(jù)庫了,然后還可以根據(jù)數(shù)據(jù)庫的當前負載采取有效的均衡策略,來調(diào)整每次連接到哪個數(shù)據(jù)庫。

2、實現(xiàn)多據(jù)庫數(shù)據(jù)同步對于負載均衡,最重要的就是所有服務器的數(shù)據(jù)都是實時同步的。這是一個集群所必需的,因為,如果數(shù)不據(jù)實 時、不同步,那么用戶從一臺服務器讀出的數(shù)據(jù),就有別于從另一臺服務器讀出的數(shù)據(jù),這是不能允許的。所以必須實現(xiàn)數(shù)據(jù)庫的數(shù)據(jù)同步。

這樣,在查詢的時候就可以有多個資源,實現(xiàn)均衡。

比較常用的方法是Moebiusfor SQL Server集群,Moebius for SQL Server集群采用將核心程序駐留在每個機器的數(shù)據(jù)庫中的辦法,這個核心程序稱為Moebius for SQL Server中間件,主要作用是監(jiān)測數(shù)據(jù)庫內(nèi)數(shù)據(jù)的變化并將變化的數(shù)據(jù)同步到其他數(shù)據(jù)庫中。數(shù)據(jù)同步完成后客戶端才會得到響應,同步過程是并發(fā)完成的,所以同步到多個數(shù)據(jù)庫和同步到一個數(shù)據(jù)庫的時間基本相等;

另外同步的過程是在事務的環(huán)境下完成的,保證了多份數(shù)據(jù)在任何時刻數(shù)據(jù)的一致性。正因為 Moebius中間件宿主在數(shù)據(jù)庫中的創(chuàng)新,讓中間件不但能知道數(shù)據(jù)的變化,而且知道引起數(shù)據(jù)變化的SQL語句, 根據(jù)SQL語句的類型智能的采取不同的數(shù)據(jù)同步的策略以保證數(shù)據(jù)同步成本的最小化。數(shù)據(jù)條數(shù)很少,數(shù)據(jù)內(nèi)容也不大,則直接同步數(shù)據(jù)。數(shù)據(jù)條數(shù)很少,但是里面包含大數(shù)據(jù)類型, 比如文本,二進制數(shù)據(jù)等,則先對數(shù)據(jù)進行壓縮然后再同步,從而減少網(wǎng)絡帶寬的占用和傳輸所用的時間。

數(shù)據(jù)條數(shù)很多,此時中間件會拿到造成數(shù)據(jù)變化的SQL語句, 然后對 SQL語句進行解析,分析其執(zhí)行計劃和執(zhí)行成本,并選擇是同步數(shù)據(jù)還是同步SQL語句到其他的數(shù)據(jù)庫中。

此種情況應用在對表結(jié)構(gòu)進行調(diào)整或者批量更改數(shù) 據(jù)的時候非常有用。 

 3、優(yōu)缺點優(yōu)點: 

1) 擴展性強:當系統(tǒng)要更高數(shù)據(jù)庫處理速度時,只要簡單地增加數(shù)據(jù)庫服務器就可以得到擴展。

2) 可維護性:當某節(jié)點發(fā)生故障時,系統(tǒng)會自動檢測故障并轉(zhuǎn)移故障節(jié)點的應用,保證數(shù)據(jù)庫的持續(xù)工作。

3) 安全性:因為數(shù)據(jù)會同步的多臺服務器上,可以實現(xiàn)數(shù)據(jù)集的冗余,通過多份數(shù)據(jù)來保證安全性。另外它成功地將數(shù)據(jù)庫放到了內(nèi)網(wǎng)之中,更好地保護了數(shù)據(jù)庫的安全性。

4) 易用性:對應用來說完全透明,集群暴露出來的就是一個IP缺點:

a) 不能夠按照Web 服務器的處理能力分配負載。

b) 負載均衡器(控制端)故障,會導致整個數(shù)據(jù)庫系統(tǒng)癱瘓。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關(guān)推薦HOT
【Python面試題】談談你對“猴子補丁”(monkey patching)的理解

“猴子補丁”是動態(tài)類型語言的一個特性,代碼運行時在不修改源代碼的前提下改變代碼中的方法、屬性、函數(shù)等以達到熱補?。╤ot patch)的效果。詳情>>

2022-08-23 10:29:17
【Python面試題】使用Python代碼實現(xiàn)遍歷一個文件夾的操作

Python標準庫os模塊的walk函數(shù)提供了遍歷一個文件夾的功能,它返回一個生成器。import os g = os.walk('/Users/Hao/Downloads/') for path, dir...詳情>>

2022-08-23 10:29:09
【Python面試題】如何理解python中的封裝,繼承,多態(tài)的

封裝:封裝就是把對象的屬性和行為結(jié)合成一個獨立的整體,把內(nèi)部的實現(xiàn)細節(jié)隱藏起來,不能被外界所看見,調(diào)用的人只能執(zhí)行,而看不到實現(xiàn)的細節(jié)...詳情>>

2022-08-23 10:29:06
【Python面試題】運行下面的代碼是否會報錯

擴展:如果不希望代碼運行時動態(tài)的給對象添加新屬性,可以在定義類時使用__slots__魔法。例如,我們可以在上面的A中添加一行__slots__ = ('__va...詳情>>

2022-08-23 10:29:03
【Python面試題】閱讀下面的代碼說出運行結(jié)果。

在沒有多重繼承的情況下,向?qū)ο蟀l(fā)出一個消息,如果對象沒有對應的方法,那么向上(父類)搜索的順序是非常清晰的。如果向上追溯到object類(所...詳情>>

2022-08-23 10:29:00
快速通道