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

2021-06-16 01:11:00 字數 735 閱讀 5784

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

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

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

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

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

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

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

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

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

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

PHP CGI程序占用過多CPU

一般情況下,php cgi只在使用者訪問的時候會占用cpu資源,但是最近有同事反映,伺服器上的的php cgi程序占用了非常多的cpu,但是訪問流量卻非常少。這顯然是乙個不正常的現象,說有些地方存在故障。以下導致此問題可能存在的原因,在此與大家分享。1.相容性問題 如果php的擴充套件與php版本相...

PHP CGI程序占用過多CPU

一般情況下,php cgi只在使用者訪問的時候會占用cpu資源,但是最近有同事反映,伺服器上的的php cgi程序占用了非常多的cpu,但是訪問流量卻非常少。這顯然是乙個不正常的現象,說有些地方存在故障。以下導致此問題可能存在的原因,在此與大家分享。1.相容性問題 如果php的擴充套件與php版本相...