在WINDOWS2003+IIS6下,經常出現w3wp的內存占用不能及時釋放,從而導致服務器響應速度很慢。
今天研究了一下,可以做以下配置:
1、在IIS中對每個網站進行單獨的應用程序池配置。即互相之間不影響。
2、設置應用程序池的回收時間,默認為1720小時,可以根據情況修改。同時,設置同時運行的w3wp進程數目為1。再設置當內存或者cpu占用超過多少,就自動回收內存
一般來說,這樣就可以解決了。但仍然會出現個別網站因為程序問題,不能正確釋放。
那么,怎么樣才能找到是哪一個網站的?
1、在任務管理器中增加顯示pid字段。就可以看到占用內存或者cpu最高的進程pid
2、在命令提示符下運行iisapp -a。注意,第一次運行,會提示沒有js支持,點擊確定。然后再次運行就可以了。這樣就可以看到pid對應的應用程序池
3、到iis中察看該應用程序池對應的網站,就ok了。
問:我的具體情況是這樣的:
服務器配置 至強2.8G 內存512M SCSI硬盤 2塊 (軟鏡像)
系統 windows 2003
現在掛了一個asp.net開發的網站 訪問量不大 但是出現一個 問題就是
每當服務器運行2-3天后 訪問網站就特別慢 重啟動服務器后就 正常了
查看進程使用內存的情況 發現w3wp.exe 和sqlservr.exe 進程 占用內存
相當大 達到了170多M( 每個) 物理可用內存幾乎用光
(服務器重啟動時 占用的內存很小才40多M 每個)
以前網站掛在一個虛擬機上 數據庫是分開掛的 從沒出現這種情況
后來 原版移植到新服務器上就 出現這樣的問題~~
還個一問題就是 我在SQL企業管理器中查看SQL進程 發現有很多是 。net 引起的進程是sleeping 但是卻占用了內存~ 無法釋放
搞了很久了 一直都沒解決
求救~~請高手 指教~~ 萬分感謝~~~~~
答:IIS服務管理器----》應用程序池----》添加你的應用,并設置最大內存,當程序達到最大內存后其會自動重啟。
我的問題跟你一樣,不過我的內存是2G的,訪問量比較高,一般是差不多運行24小時后就得重啟,內存沒耗完,W3WP進程占到一百八九十兆,SQL占了二百多兆時,就得重啟,不然整個站點就當在那邊....55555555,搞了快半個月了還是不行,痛苦啊
w3wp.exe就是你的ASP.NET應用宿主,如果你使用了大量的session、Cache等資源,并且Session超市時間很長,那么內存占用量就比較大。應用池是為增加性能而設的一個特性,但是也消耗很大的內存。另外關掉Windows Server 2003里的大多數Service(那個不用都可以關掉),也可以節省一部分內存
1.懷疑在程序中應用的CACHE,
2.CACHE中有大量的數據
3.頻繁刷新CACHE
4.沒有設計好CACHE的方式
你的問題我以前也遇見過,我以前是用的Session,后我全部改成cook之后就好多了,應該是你的Session或是你的CACHE有問題(CACHE不太懂,但多多少應該是有的)
跟蹤下SQL的調用記錄,在每次往CACHE或SESSION寫入大量數據時記錄一下時間,看是否太過頻繁
1.在win2003里asp.net的進程就是w3wp.exe
2.512M內存個人用是夠用了,但是放在服務器上就有點不夠用了,尤其是win2003 + asp.net +sql server 。尤其是sql server 他是很吃內存的,如果不控制的話,他會占光所有的物理內存(只剩下幾十M 倒 100M 吧)。win2003 本身就要占用150M左右。也就剩不下什么了。
3.優化asp.net程序,就向樓上的說的那樣,少用或不用session cache application之類的東西,再有就是是不是有翻頁的地方,翻頁處理不好也是會占很多內存的。
4.限制sql的內存。企業管理器——SQL的屬性(一般是local)——“內存”標簽
在這里看內存的設置,把最大值改成100M吧。
第四條是最快的方法,可以試一試。
我的一個自開發OA系統也存在這樣的問題。
總結上面,大概原因是因為 session 和 cache 的不合理使用造成的。
我的應用程序中,確實用了很多的Session 和 Cache,
在 MSDN 中找到 了 “動態內存分配”這一篇,今天就試看看,是否有效。
希望有經驗的朋友多給些信息,大家也好總結下出現類似錯誤的原因,謝謝!!
不知道你是什么網站。按理說是不會占用這么大的。如上你用了cache存放了超額的內容。當然。象session這種是不太可能占用這么大的了,或用了application 類似的一些有超長時間或永久保持性的對象來保存大量數據。如利用單例保存數據這些都有可能造成使用大量的內存。
建義2003系統安裝至少1G內存。
w3wp.exe是2003下的一個iis進程,至于樓主說的sql占用內存,那有可能是因為你的sql沒有設置占用內存上限
在IIS6下,經常出現w3wp.exe的內存及CPU占用不能及時釋放,從而導致服務器響應速度很慢。
解決內存占用過多,可以做以下配置:
1、在IIS中對每個網站進行單獨的應用程序池配置。即互相之間不影響。
2、設置應用程序池的回收時間,默認為1720小時,可以根據情況修改。再設置當內存占用超過多少(如500M),就自動回收內存。
解決CPU占用過多:
1、在IIS中對每個網站進行單獨的應用程序池配置。即互相之間不影響。
2、設置應用程序池的CPU監視,不超過25%(服務器為4CPU),每分鐘刷新,超過限制時關閉。
根據w3wp取得是那個一個應用程序池:
1、在任務管理器中增加顯示pid字段。就可以看到占用內存或者cpu最高的進程pid
2、在命令提示符下運行iisapp -a。注意,第一次運行,會提示沒有js支持,點擊確定。然后再次運行就可以了。這樣就可以看到pid對應的應用程序池。(iisapp實際上是存放在C:/windows/system32目錄下的一個VBS腳本,全名為iisapp.vbs,如果你和我一樣,也禁止了Vbs默認關聯程序,那么就需要手動到該目錄,先擇打開方式,然后選“Microsoft (r) Windows Based Script Host”來執行,就可以得到PID與應用程序池的對應關系。)
3、到iis中察看該應用程序池對應的網站,就ok了,做出上面的內存或CPU方面的限制,或檢查程序有無死循環之類的問題。
新聞熱點
疑難解答