ASP.NET中的OutOfMemoryException(from kaneboy)

來源:http://www.cnblogs.com/gxh973121/archive/2005/05/08/150607.html

在博客園看到了一位園友寫的文章《如何處理OutOfMemoryException異常?》,於是想和大家交流一下ASP.NET中出現OutOfMemoryException的問題。

實際上,在ASP.NET Web服務器上,ASP.NET所能夠用到的內存,通常不會等同於所有的內存數量。在machine.config配置文件中,<processModel>中有一個屬性“memoryLimit”,這個屬性的值是一個百分值,默認爲“60”,即指定了ASP.NET進程(在任務管理器中大家就可以看到ASP.NET的進程,IIS5中爲aspnet_wpIIS6中爲w3wp)能夠使用所有物理內存的60%。當ASP.NET使用的內存量超過這個限額時,IIS會開始自動回收(recycle)進程,即創建一個新的進程去負責應付Http請求,而將舊進程所佔用的內存回收。

當我們有一臺很大內存的服務器時,“memoryLimit”這個值是需要進行適當的調整的。比如我們準備了一臺4G內存的服務器,那麼4G×60%2.4G。但是,對於Win32操作系統,一個進程所能佔用的所有內存空間只有2G。當ASP.NET進程佔用的內存開始達到2G時,由於它並沒有達到2.4G回收閾值,所以IIS不會啓動recycle進程操作,但是由於Win32的限制,實際上已經不能給這個進程分配更多的內存了,於是,OutOfMemoryException就很可能會被拋出了。爲了避免這樣的情況,我們就必須將“memoryLimit”適當調小,以讓IIS更早的進行進程回收。

微軟推薦的ASP.NET進程佔用內存是不超過60%,並最好使計算出的實際值不超過800M。就是說,對於一臺4G內存的服務器,最好將“memoryLimit”屬性設置成“20”。設置一個適當的回收閾值,讓IIS適時的進行進程回收,對於保證整個服務器的穩定運行,避免OutOfMemoryException是非常重要的。

IIS6中,ASP.NET進程的回收閾值不再由配置節中的“memoryLimit”屬性決定,而是由IIS管理器中的應用程序池配置中的設置決定。

但是,即使正確設置了這些配置,也不能保證完全避免OutOfMemoryException的發生,原因可能是多樣而複雜的,比如內存回收操作可能耗時太多等等。開發人員要注意的,就是在代碼中時刻牢記不要無謂的使用和浪費內存。:)

如果你有一臺大內存的服務器,同時對Win32操作系統中對於進程最高使用2G內存的限制很鬱悶,可選的解決方法有兩個:
1
、使用/3GB模式啓動計算機,方法參加文後的鏈接
2
、使用Windows Server 2003 64bits Edition

資源鏈接:
Microsoft IIS 5.0 Process Recycling Tool
,使IIS5具有類似IIS6的進程監視回收功能
Microsoft KB: Information on Application Use of 4GT RAM Tuning
Microsoft KB: 4 GB RAM 調試功能和物理地址擴展開關介紹
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章