解決占用過多記憶體的簡單方法

2021-04-17 04:32:37 字數 735 閱讀 9345

經常看見有人問,mssql占用了太多的記憶體,而且還不斷的增長;或者說已經設定了使用記憶體,可是它沒有用到那麼多,這是怎麼一回事兒呢?

首先,我們來看看mssql是怎樣使用記憶體的。

最大的開銷一般是用於資料快取,如果記憶體足夠,它會把用過的資料和覺得你會用到的資料統統扔到記憶體中,直到記憶體不足的時候,才把命中率低的資料給清掉。所以一般我們在看statisticsio的時候,看到的physicsread都是0。

其次就是查詢的開銷,一般地說,hashjoin是會帶來比較大的記憶體開銷的,而mergejoin和nestedloop的開銷比較小,還有排序和中間表、游標也是會有比較大的開銷的。

所以用於關聯和排序的列上一般需要有索引。

再其次就是對執行計畫、系統資料的儲存,這些都是比較小的。

我們先來看資料快取對效能的影響,如果系統中沒有其它應用程式來爭奪記憶體,資料快取一般是越多越好,甚至有些時候我們會強行把一些資料pin在快取記憶體中。但是如果有其它應用程式,雖然在需要的時候mssql會釋放記憶體,但是執行緒切換、io等待這些工作也是需要時間的,所以就會造成效能的降低。這樣我們就必須設定mssql的最大記憶體使用。可以在屬性(記憶體選項卡)中找到配置最大使用記憶體的地方,或者也可以使用sp_configure來完成。如果沒有其它應用程式,那麼就不要限制mssql對記憶體的使用。

然後來看查詢的開銷,這個開銷顯然是越低越好,因為我們不能從中得到好處,相反,使用了越多的記憶體多半意味著查詢速度的降低。所以我們一般要避免中間表和游標的使用,在經常作關聯和排序的列上建立索引。

關於占用過多記憶體的問題

經常看見有人問,mssql占用了太多的記憶體,而且還不斷的增長 或者說已經設定了使用記憶體,可是它沒有用到那麼多,這是怎麼一回事兒呢?首先,我們來看看mssql是怎樣使用記憶體的。最大的開銷一般是用於資料快取,如果記憶體足夠,它會把用過的資料和覺得你會用到的資料統統扔到記憶體中,直到記憶體不足的時候...

解決win7下svchost程序占用過多CPU資源

安轉原版的win7 64bit系統,開機一段時間後發現cpu風扇一直工作,開啟任務管理器,找到如下程序 svchost.exe,然後右鍵轉到服務,有如下幾項。這是windows update的影響,比較簡單的解決辦法 先結束程序樹,cpu溫度隨之降下來了,找到目錄 c windows softwar...

判斷記憶體洩露的簡單方法

mfc提供了檢查記憶體的類cmemorystate,我們就利用這個類的物件來檢查記憶體洩露,以下是具體步驟 一 在你所檢測的程式段的開始處建立乙個 cmemorystate 物件,呼叫其成員函式checkpoint,以取得當前記憶體使用情況的快照 二 在你所檢測的程式段的末尾處再建立乙個 cmemo...