MSSQL數(shù)據(jù)庫(kù)占用內(nèi)存過(guò)大造成服務(wù)器死機(jī)問(wèn)題的解決方法
發(fā)布日期:2022-01-01 19:46 | 文章來(lái)源:源碼之家
在您啟動(dòng) SQL Server 之后,SQL Server 內(nèi)存使用量將會(huì)持續(xù)穩(wěn)定上升,即使當(dāng)服務(wù)器上活動(dòng)很少時(shí)也不會(huì)下降。另外,任務(wù)管理器和性能監(jiān)視器將顯示計(jì)算機(jī)上可用的物理內(nèi)存穩(wěn)定下降,直到可用內(nèi)存降到 4 至 10 MB 為止。
僅僅出現(xiàn)這種狀態(tài)不表示內(nèi)存泄漏。此行為是正常的,并且是 SQL Server 緩沖池的預(yù)期行為。
默認(rèn)情況下,SQL Server 根據(jù)操作系統(tǒng)報(bào)告的物理內(nèi)存加載動(dòng)態(tài)增大和收縮其緩沖池(緩存)的大小。只要有足夠的內(nèi)存可用于防止內(nèi)存頁(yè)面交換(在 4 至 10 MB 之間),SQL Server 緩沖池就會(huì)繼續(xù)增大。像在與 SQL Server 分配內(nèi)存位于相同計(jì)算機(jī)上的其他進(jìn)程一樣,SQL Server 緩沖區(qū)管理器將在需要的時(shí)候釋放內(nèi)存。SQL Server 每秒可以釋放和獲取幾兆字節(jié)的內(nèi)存,從而使它可以快速適應(yīng)內(nèi)存分配變化。
更多信息
您可以通過(guò)服務(wù)器內(nèi)存最小值和服務(wù)器內(nèi)存最大值配置選項(xiàng)設(shè)置 SQL Server 數(shù)據(jù)庫(kù)引擎使用的內(nèi)存(緩沖池)量的上下限。在設(shè)置服務(wù)器內(nèi)存最小值和服務(wù)器內(nèi)存最大值選項(xiàng)之前,請(qǐng)查閱以下 Microsoft 知識(shí)庫(kù)文章中標(biāo)題為"內(nèi)存"一節(jié)中的參考信息:
319942 HOW TO:Determine Proper SQL Server Configuration Settings(確定正確的 SQL Server 配置設(shè)置)
請(qǐng)注意,服務(wù)器內(nèi)存最大值選項(xiàng)只限制 SQL Server 緩沖池的大小。服務(wù)器內(nèi)存最大值選項(xiàng)不限制剩余的未保留內(nèi)存區(qū)域,SQL Server 準(zhǔn)備將該區(qū)域分配給其他組件,例如擴(kuò)展存儲(chǔ)過(guò)程、COM 對(duì)象、以及非共享 DLL、EXE 和 MAPI 組件。由于前面的分配,SQL Server 專用字節(jié)超過(guò)服務(wù)器內(nèi)存最大值配置是很正常的。有關(guān)此未保留內(nèi)存區(qū)域中分配的其他信息,請(qǐng)單擊下面的文章編號(hào),以查看 Microsoft 知識(shí)庫(kù)中相應(yīng)的文章:
316749 PRB:在使用大量數(shù)據(jù)庫(kù)時(shí)可能沒(méi)有足夠的虛擬內(nèi)存
參考
SQL Server 聯(lián)機(jī)圖書;主題:"服務(wù)器內(nèi)存最小值和最大值的影響";"內(nèi)存體系結(jié)構(gòu)";"服務(wù)器內(nèi)存選項(xiàng)";"SQL Server 內(nèi)存池" 下面我們就來(lái)實(shí)戰(zhàn)如何限制MSSQL內(nèi)存使用: 第一步:打開(kāi)企業(yè)管理雙擊進(jìn)入要修改的MSSQL.
第二步:在左側(cè)MSSQL上點(diǎn)擊右鍵,選擇屬性,彈出SQL Server屬性(配置)對(duì)話框
第三步:點(diǎn)擊內(nèi)存選項(xiàng)卡.
在這里,你會(huì)看到MSSQL默認(rèn)設(shè)置為使用最大內(nèi)存,也就是你所有的內(nèi)存,根據(jù)你的需要,設(shè)置它的最大值吧.
第五步:設(shè)置完畢,關(guān)閉MSSQL服務(wù)再重啟,配置即可生效!
更多信息
您可以通過(guò)服務(wù)器內(nèi)存最小值和服務(wù)器內(nèi)存最大值配置選項(xiàng)設(shè)置 SQL Server 數(shù)據(jù)庫(kù)引擎使用的內(nèi)存(緩沖池)量的上下限。在設(shè)置服務(wù)器內(nèi)存最小值和服務(wù)器內(nèi)存最大值選項(xiàng)之前,請(qǐng)查閱以下 Microsoft 知識(shí)庫(kù)文章中標(biāo)題為"內(nèi)存"一節(jié)中的參考信息:
319942 HOW TO:Determine Proper SQL Server Configuration Settings(確定正確的 SQL Server 配置設(shè)置)
請(qǐng)注意,服務(wù)器內(nèi)存最大值選項(xiàng)只限制 SQL Server 緩沖池的大小。服務(wù)器內(nèi)存最大值選項(xiàng)不限制剩余的未保留內(nèi)存區(qū)域,SQL Server 準(zhǔn)備將該區(qū)域分配給其他組件,例如擴(kuò)展存儲(chǔ)過(guò)程、COM 對(duì)象、以及非共享 DLL、EXE 和 MAPI 組件。由于前面的分配,SQL Server 專用字節(jié)超過(guò)服務(wù)器內(nèi)存最大值配置是很正常的。有關(guān)此未保留內(nèi)存區(qū)域中分配的其他信息,請(qǐng)單擊下面的文章編號(hào),以查看 Microsoft 知識(shí)庫(kù)中相應(yīng)的文章:
316749 PRB:在使用大量數(shù)據(jù)庫(kù)時(shí)可能沒(méi)有足夠的虛擬內(nèi)存
參考
SQL Server 聯(lián)機(jī)圖書;主題:"服務(wù)器內(nèi)存最小值和最大值的影響";"內(nèi)存體系結(jié)構(gòu)";"服務(wù)器內(nèi)存選項(xiàng)";"SQL Server 內(nèi)存池" 下面我們就來(lái)實(shí)戰(zhàn)如何限制MSSQL內(nèi)存使用: 第一步:打開(kāi)企業(yè)管理雙擊進(jìn)入要修改的MSSQL.



版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。
相關(guān)文章