怎樣合理設(shè)置內(nèi)存讓數(shù)據(jù)庫與其他程序共存_Mssql數(shù)據(jù)庫教程
推薦:怎樣優(yōu)化SQLServer數(shù)據(jù)庫服務(wù)器內(nèi)存配置怎樣優(yōu)化SQLServer數(shù)據(jù)庫服務(wù)器內(nèi)存配置 2009-05-28 00:37 農(nóng)業(yè)銀行總行1998年以來正式推廣了新版網(wǎng)絡(luò)版綜合業(yè)務(wù)統(tǒng)計信息系統(tǒng),該系統(tǒng)是基于WindowsNT4.0平臺,采用客戶/服務(wù)器模式,以Microsoft SQL Server為基礎(chǔ)建立起來的大型數(shù)據(jù)庫應(yīng)用程序,系統(tǒng)界面友
在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)存。

一、SQL SERVER數(shù)據(jù)庫的內(nèi)存管理機(jī)制。
在數(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è)置的時候,最好能夠留有一定的余地。
分享:談SQL Server數(shù)據(jù)庫管理常用的SQL和T-SQL語句1. 查看數(shù)據(jù)庫的版本 select @@version 2. 查看數(shù)據(jù)庫所在機(jī)器操作系統(tǒng)參數(shù) exec master..xp_msver 3. 查看數(shù)據(jù)庫啟動的參數(shù) sp_configure 4. 查看數(shù)據(jù)庫啟動時間 select convert(varchar(30),login_time,120) from master..sysprocesses where spid=1 查看
- sql 語句練習(xí)與答案
- 深入C++ string.find()函數(shù)的用法總結(jié)
- SQL Server中刪除重復(fù)數(shù)據(jù)的幾個方法
- sql刪除重復(fù)數(shù)據(jù)的詳細(xì)方法
- SQL SERVER 2000安裝教程圖文詳解
- 使用sql server management studio 2008 無法查看數(shù)據(jù)庫,提示 無法為該請求檢索數(shù)據(jù) 錯誤916解決方法
- SQLServer日志清空語句(sql2000,sql2005,sql2008)
- Sql Server 2008完全卸載方法(其他版本類似)
- sql server 2008 不允許保存更改,您所做的更改要求刪除并重新創(chuàng)建以下表
- SQL Server 2008 清空刪除日志文件(瞬間日志變幾M)
- Win7系統(tǒng)安裝MySQL5.5.21圖解教程
- 將DataTable作為存儲過程參數(shù)的用法實(shí)例詳解
- 相關(guān)鏈接:
- 教程說明:
Mssql數(shù)據(jù)庫教程-怎樣合理設(shè)置內(nèi)存讓數(shù)據(jù)庫與其他程序共存
。