合理設(shè)置內(nèi)存讓數(shù)據(jù)庫與其他程序共存
當(dāng)前位置:點(diǎn)晴教程→知識管理交流
→『 技術(shù)文檔交流 』
在SQL Server數(shù)據(jù)庫中,有min server memory與max server memory兩個內(nèi)存選項(xiàng)。數(shù)據(jù)庫管理員合理設(shè)置這兩個選項(xiàng)可以讓SQL SERVER數(shù)據(jù)庫系統(tǒng)與其他英勇程序和平共存。顧名思義,min server memory就是設(shè)置數(shù)據(jù)系統(tǒng)所使用的最小內(nèi)存,而max server memory用來設(shè)置其可以使用的最大內(nèi)存。
在數(shù)據(jù)庫啟動的時候,其實(shí)數(shù)據(jù)庫引擎并不會馬上在內(nèi)存中抓取min參數(shù)規(guī)定的內(nèi)存量。這種占著茅坑不拉屎的事情SQL Server數(shù)據(jù)庫是不會做的。系統(tǒng)在剛開始啟動的時候,數(shù)據(jù)庫緩沖池只抓取初始化所需要的內(nèi)存,如上圖所示。數(shù)據(jù)庫啟動之后隨著業(yè)務(wù)量的增大,數(shù)據(jù)庫引擎的工作負(fù)荷也會隨之增加。此時數(shù)據(jù)庫引擎會繼續(xù)獲取完成工作所需要的內(nèi)存。在達(dá)到min規(guī)定的內(nèi)存數(shù)量之前,數(shù)據(jù)庫引擎緩沖池是不會釋放它獲取的任何內(nèi)存。如數(shù)據(jù)庫初始化內(nèi)存為20M,而規(guī)定的min內(nèi)存數(shù)量為50M。則可能因?yàn)橛脩舨樵兡硞€負(fù)責(zé)報表的需要,內(nèi)存需要量會達(dá)到40M。查詢作業(yè)執(zhí)行完畢后數(shù)據(jù)庫系統(tǒng)緩沖池實(shí)際使用的內(nèi)存量可能只需要20M即可。但是只要沒有達(dá)到50M這個值。則數(shù)據(jù)庫系統(tǒng)不會把沒有的20M內(nèi)存還給操作系統(tǒng),而是一直占用著,以方面后續(xù)的作業(yè)。 如果用戶需要調(diào)用數(shù)據(jù)庫系統(tǒng)中的函數(shù)或者過程,此時內(nèi)存的需要量可能會超過規(guī)定的最小內(nèi)存量,如達(dá)到80M。此時數(shù)據(jù)庫引擎會根據(jù)一定的標(biāo)準(zhǔn)算法,根據(jù)需要來獲取和釋放內(nèi)存。當(dāng)需要使用超過50M的內(nèi)存的時候,只要沒有達(dá)到內(nèi)存的最大限值之前,則會根據(jù)系統(tǒng)提供的標(biāo)準(zhǔn)算法來獲取內(nèi)存。至于這個標(biāo)準(zhǔn)算法到底是怎么樣的,這不是我們數(shù)據(jù)庫管理員所需要關(guān)注的內(nèi)容。然后等到這個過程或者函數(shù)調(diào)用完畢后,內(nèi)存使用量可能會降低到最低內(nèi)存數(shù)量以下,如又回復(fù)到40M。此時數(shù)據(jù)庫引擎就會釋放內(nèi)存,把沒有用到的內(nèi)存釋放出來給其他應(yīng)用程序使用。但是這個釋放會有一個限制。數(shù)據(jù)庫引擎緩沖池從不將內(nèi)存分配降低到最小內(nèi)存所指定的水平下。也就是說,此時數(shù)據(jù)庫最多會釋放30M的內(nèi)存,為自己留下50M的內(nèi)存空間,即使當(dāng)前其可能只需要用到40M內(nèi)存空間即可。當(dāng)然在抓取內(nèi)存空間的時候,其也不會為自己分配高于MAX內(nèi)存所規(guī)定的內(nèi)存空間。 二、內(nèi)存參數(shù)配置對其他應(yīng)用系統(tǒng)的影響。 在一臺服務(wù)器上,往往多個應(yīng)用程序需要共享內(nèi)存。如可能在一臺服務(wù)器上部署了多個應(yīng)用系統(tǒng),至少在一臺服務(wù)器上操作系統(tǒng)與SQL Server數(shù)據(jù)庫之間需要共存。為此SQL Server數(shù)據(jù)庫可以使用多少的內(nèi)存空間,肯定會對其他的應(yīng)用程序產(chǎn)生比較大的影響。 如在一臺服務(wù)器上部署了SQL Server數(shù)據(jù)庫系統(tǒng)、郵件應(yīng)用系統(tǒng)、ERP應(yīng)用服務(wù)器等等三個應(yīng)用系統(tǒng)。如果先啟動SQL Server數(shù)據(jù)庫系統(tǒng),后來又要啟動郵件應(yīng)用系統(tǒng),此時郵件應(yīng)用系統(tǒng)的啟動速度就會受到影響。因?yàn)槟承?yīng)用程序在初始化的過程中可能會需要用到比較大的內(nèi)存空間。而在啟動的過程中,可能數(shù)據(jù)庫在使用的內(nèi)存比較多,剩余的內(nèi)存不能夠滿足其他應(yīng)用程序啟動的需要。此時其他應(yīng)用程序在啟動時就會等待,等待數(shù)據(jù)庫應(yīng)用程序釋放內(nèi)存。這就會延長其他應(yīng)用程序的啟動時間。 另外在執(zhí)行某些工作的時候,也會影響到。如在同一個時間對數(shù)據(jù)庫與郵箱服務(wù)器進(jìn)行備份作業(yè)。由于備份作業(yè)需要用到比較多的內(nèi)存,此時就會發(fā)生內(nèi)存爭用選項(xiàng)。為此如果能夠把數(shù)據(jù)庫的最低內(nèi)存設(shè)置的比較低的話,則數(shù)據(jù)庫系統(tǒng)在用完內(nèi)存話就可以馬上把內(nèi)存釋放出來,而不會為自己保留比較大的暫時不同的內(nèi)存空間。同理,在保障業(yè)務(wù)需求的情況下把最大內(nèi)存設(shè)置的比較小,則可以為其他應(yīng)用程序留下比較多的內(nèi)存空間。 三、多個應(yīng)用程序共存時的內(nèi)存分配。
如果一臺服務(wù)器上只運(yùn)行了一個數(shù)據(jù)庫應(yīng)用程序,或者說數(shù)據(jù)庫的應(yīng)用比較簡單、數(shù)據(jù)庫內(nèi)存使用量基本上不會超過最小內(nèi)存數(shù)量的花,則可以采用默認(rèn)多參數(shù)配置。但是如果在同一臺服務(wù)器上部署了比較多的應(yīng)用程序或者數(shù)據(jù)庫設(shè)計比較復(fù)雜,此時就需要對數(shù)據(jù)庫的最小內(nèi)存與最大內(nèi)存進(jìn)行配置,以實(shí)現(xiàn)多個應(yīng)用程序能夠?qū)崿F(xiàn)和平共處。另外如果數(shù)據(jù)庫本身比較簡單,但是其他應(yīng)用程序比較復(fù)雜,可能會占用90%以上的內(nèi)存時,數(shù)據(jù)庫就需要采用一定的保護(hù)措施,需要設(shè)置最小內(nèi)存與最大內(nèi)存,來保障自己數(shù)據(jù)庫正常運(yùn)行所需要的內(nèi)存空間。 1、數(shù)據(jù)庫管理員需要監(jiān)測內(nèi)存的使用情況,并根據(jù)監(jiān)測的數(shù)據(jù)來進(jìn)行設(shè)置。由于采取的操作系統(tǒng)、部署的應(yīng)用程序不同;甚至在SQL Server數(shù)據(jù)庫中啟用的服務(wù)不同,數(shù)據(jù)庫需要使用的內(nèi)存數(shù)量也是不同的。為此沒有一個具體的標(biāo)準(zhǔn)說最小內(nèi)存或者最大內(nèi)存要配置多少。通常情況下需要數(shù)據(jù)庫管理員跟蹤數(shù)據(jù)庫服務(wù)器一段時間,看看其內(nèi)存的使用量。如筆者建議用戶,數(shù)據(jù)庫系統(tǒng)正是投入使用后,在頭一年內(nèi)需要每個月觀測一下內(nèi)存的使用情況。由于頭幾個月可能使用的不穩(wěn)定,所得到的數(shù)據(jù)參考價值不大。而從第六個月開始到第12個月近八個月數(shù)據(jù)庫內(nèi)存的使用情況來看,基本上可以得出一個最小內(nèi)存與最大內(nèi)存的合理范圍。然后數(shù)據(jù)庫管理員就可以來對內(nèi)存的最大最小值來進(jìn)行設(shè)置。以后若前臺應(yīng)用程序做了新的調(diào)整或者數(shù)據(jù)庫中采用了新的功能,仍然需要對內(nèi)存的使用情況進(jìn)行監(jiān)測,來確定一個合理的內(nèi)存使用范圍。一般來說,最好把最小內(nèi)存設(shè)置的小一點(diǎn),而把最大內(nèi)存的花設(shè)置的大一點(diǎn)。如此的話,可以讓數(shù)據(jù)庫引擎在管理內(nèi)存的時候有比較大的靈活性。然后再進(jìn)行后續(xù)監(jiān)測的數(shù)據(jù)來進(jìn)行相應(yīng)的調(diào)整,慢慢的把內(nèi)存配置調(diào)整到優(yōu)選。根據(jù)筆者的經(jīng)驗(yàn),要達(dá)到合理的內(nèi)存配置之前,往往需要一個比較漫長的時間。不過這對于數(shù)據(jù)庫性能優(yōu)化來說,可能這個過程也不是很長。 2、要分析數(shù)據(jù)庫系統(tǒng)內(nèi)存的使用大戶,跟其他應(yīng)用程序的內(nèi)存使用高峰分流。數(shù)據(jù)庫中函數(shù)、過程、復(fù)雜的視圖、備份等作業(yè)都會用到比較可觀的內(nèi)存。如企業(yè)如果在SQL SERVER數(shù)據(jù)庫上面部署了ERP系統(tǒng),而系統(tǒng)中有一個“庫存采購”作業(yè),這個需要用到比較復(fù)雜的業(yè)務(wù)邏輯,需要考慮到庫存、安全庫存、包裝數(shù)量等等比較復(fù)雜的計算。為此最好能夠把這個作業(yè)放到服務(wù)器比較空的時候運(yùn)行,以跟其他應(yīng)用程序錯開運(yùn)行。如在應(yīng)用程序設(shè)計的時候,可以把這個作業(yè)放在后臺運(yùn)行,并讓其在晚上12點(diǎn)運(yùn)行。然后在第二天早上之前出來結(jié)果。另外每個應(yīng)用程序都需要對自己的數(shù)據(jù)進(jìn)行備份,以防不時之需。而備份程序往往也需要用到比較多的內(nèi)存。為此最好能夠把各種應(yīng)用程序的備份作業(yè)錯開來運(yùn)行。如此的話可以減少應(yīng)用程序之間內(nèi)存的占用。 四、數(shù)據(jù)庫內(nèi)存分配的特殊情況。 如果在同一個服務(wù)器上部署多個應(yīng)用程序的話,內(nèi)存的爭用是在所難免的。為此數(shù)據(jù)庫管理員往往需要為數(shù)據(jù)庫分配合適的內(nèi)存參數(shù),保證數(shù)據(jù)庫即能夠滿足其日常運(yùn)行的需要,又盡量減少對其他應(yīng)用程序的不良影響。在參數(shù)配置的過程中,除了需要考慮如上幾個建議之外,還需要注意數(shù)據(jù)庫內(nèi)存分配中的特殊情況。 如果把最小內(nèi)存與最大內(nèi)存的值設(shè)置為相同,那么會產(chǎn)生什么情況呢?如果把它們設(shè)置為相同的值,則一旦分配給數(shù)據(jù)庫引擎的內(nèi)存達(dá)到這個值的話,則數(shù)據(jù)庫引擎將停止為緩沖池動態(tài)釋放和獲取內(nèi)存。也就是說,此時數(shù)據(jù)庫內(nèi)存的分配就是固定的,不會根據(jù)數(shù)據(jù)庫引擎的負(fù)荷來動態(tài)的獲取或者釋放。顯然對于生成用的服務(wù)器來說,這并不是一個很好的配置。但是在一些特殊的應(yīng)用下,卻可以起到比較不錯的效果。如需要測試數(shù)據(jù)庫某個作業(yè)與內(nèi)存之間的關(guān)系,那么就有可能需要把它們的值配置為相同。另外如果服務(wù)器中只運(yùn)行了數(shù)據(jù)庫應(yīng)用程序,那就有可能需要把這兩個參數(shù)設(shè)置的比較高,以減少數(shù)據(jù)庫內(nèi)存釋放與獲取時所發(fā)生的額外開銷等等。 另外數(shù)據(jù)庫運(yùn)行過程中的某些作業(yè)是不受這個最大內(nèi)存的限制的。如數(shù)據(jù)庫中的進(jìn)程可能會得到超過最大內(nèi)存選項(xiàng)所指定的內(nèi)存;數(shù)據(jù)庫的一些外部組建也可以得到緩沖池以外的內(nèi)存。不過在大部分情況下,數(shù)據(jù)庫運(yùn)行還是受到這個緩沖池內(nèi)存的限制的。所以說在內(nèi)存參數(shù)設(shè)置的時候,最好能夠留有一定的余地。 該文章在 2011/5/5 22:14:14 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |