天天看點

應用程式池死

解決方法如下: 

Internet 資訊服務(IIS)管理器->應用程式池->DefaultAppPool->右擊屬性 

一、回收 

1、回收工作程序(分鐘):選中,值為1740 

2、回收工作程序(請求數目):不選(原先設定為35000) 

3、在下列時間回收工作程序:不填 

4、消耗太多記憶體時回收工作程序:全不選。(2、3、4項可能避免了在通路量高的時候強制回收程序可能引發的伺服器響應問題,導緻iis假死不響應) 

二、性能 

隻選中空閑逾時20分鐘。其他都不選。WEB園最大工作程序數為1(預設)。注意web園這裡一定要保持預設,如果填寫其他超過1的數字就會導緻一些網站程式的背景程式打不開或者重新整理不停。 

原來的請求隊列限制為4000,現在無限制。 

三、運作狀況 

前兩項都起用,是原來的預設設定。啟動時間限制90秒,關閉時間限制180秒。 

啟動快速失敗保護的鈎去掉! 

為了避免真的遇到很多錯誤時沒有提示,可以不關閉,隻是把快速保護的保護範圍加大些,例如失敗數50次 時間段5分鐘 則關閉對應的程式。 

“關閉時間限制180秒”是必須的,因為程序關閉的時間,原來為90秒限制,是預設值,如果程序關閉時間超過90秒,則認為逾時,進而出現:程序關閉時間超過了限制 日志,是以,适當延長這個時間,可以避免這種錯誤 

第2種方法: 

原因:獨立程序的 記憶體堆戋消耗完了,IIS不能建立更多的程序工作空間來處理 

解決方法: 

1. HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\W3SVC 

2. 在Parameters鍵下建立一個DWORD項,名字為:UseSharedWPDesktop 值為1 重新開機IIS 

第3種 

問題已解決,發現是資料庫連接配接無法釋放,不知道是什麼原因,同樣的代碼在本地就是好的,在伺服器端就有問題,最後在連接配接串裡加入以下語句解決問題. 

Pooling=true; MAX Pool Size=512;Min Pool Size=50;Connection Lifetime=30 

第4種 

建立應用程式池,不同的網站引用不同程式池。

問題已解決,發現是資料庫連接配接無法釋放,不知道是什麼原因,同樣的代碼在本地就是好的,在伺服器端就有問題,最後在連接配接串裡加入以下語句解決問題.

Pooling=true; MAX Pool Size=512;Min Pool Size=50;Connection Lifetime=30

第4種

為應用程式池 'AppPool #1' 提供服務的程序關閉時間超過了限制。程序 ID 是 '3000'。

出現上面情況後,該應用程式池對應的網站就通路的非常慢,幾乎是打不開。

這種現象是不是iis假死?

重新開機下該站點,問題可以得到解決。

可能是應用程式池設定問題,不知道具體應該怎麼設定!

請高手指點。

程式代碼解決辦法:

1 設定程序池回收時間.在程序池屬性裡.

2 如果你的程式是使用 asp + acc 資料庫.且acc資料庫大于30m.建議更換sql資料庫. acc資料庫大于這個值.2003系統下會造成iis6的頻繁假死.2000下會造成dllhost.exe占用大量cpu及記憶體資源.都會嚴重影響web通路速度.

3 asp程式存在死循環.

4 可使用 microsoft office 壓縮修複acc資料庫,須先備份.

引用内容2003應用程式池假死常見問題及解決方法

2006-10-09 09:48

經常見到大家談起,2003應用程式池自動死了,不能恢複了,一直出現 Service Unavailable 常見方法如下。

1:以前沒有SP1打更新檔的時候會出現這個IIS6。0假死問題,但現在微軟都在自動更新裡面出更新檔了,一般你打好最新更新檔後是不會出現此問題了。(是以現在的IIS假死與這個關系不是很大)

2:從IIS6.0開始CPU資源都在應用池裡面限制了,不象以前的IIS。5。是以假死的池的緣故就是池被拉死,你在網站打不開的時候可以看到你的某個應用池是禁用的,上面出現一個紅叉。你滑鼠右鍵啟動網站又會自動恢複。 這個原因:大概是以下幾個因數造成的。

(1):你限制了應用池的資源限制,限制得太小 比如:50這樣或更少更多一點,這個時候如果你這個池下面的網站占用CPU太高,比如超過50% 那麼5分鐘後他就自動死了,手工預設建立的應用池預設是超過資源不操作。

出現上面這個情況解決方法:1:不限制CPU資源,(這個是不可取的,不限制資源,有的程式有BUG占用資源厲害了的,伺服器都會被拉死,你可能都無法操作伺服器。)2:在超過資源那裡選擇 關閉,這個關閉預設是失敗5次,90秒内恢複,一般預設就可。網站能自動恢複,這個關閉:不是永久關閉,意思是超過資源關閉,然後在某時間内自動恢複池。不操作就是不恢複,這個是很多人的誤區。上次我寫過相關的這個講解了。

(2):記憶體限制 在IIS6。0應用池上面有虛拟記憶體和最大記憶體限制,如果你設定了這個。那麼網站通路量大了 也會出現假死,是以不建議設定這裡。預設就可。

3:就是伺服器自身記憶體太小,網站運作當然需要使用到記憶體了,當記憶體不夠的時候應用池也會死掉變成禁用。那麼隻有等記憶體全部釋放出來才能恢複應用池了。出現這個情況:那麼你就要考慮加記憶體或者檢查到底是什麼程式占用了記憶體了。比如MSSQL資料庫,這個可

是吃記憶體得大戶啊,最好别和WEB伺服器同時一個伺服器上。很多人用1G記憶體做 2003系統,2003NET結構是很占用記憶體的,是以做伺服器選2003還得把記憶體加到2G或更高才好。 記憶體不夠上面 2點講到的,是沒辦法操作了,也無法自動恢複。

4:就是ACCESS資料庫太大或查詢太多,這個也會出現把IIS拉死,解決方法;修複ACCESS資料庫,或盡量少用ACCESS資料庫。

5:不同網站用不同應用池:根據你自己實際情況而定,站點大的最好獨立一個應用池,限制他的資源超過了自動回收,看上面 (1)講到的,這樣就不影響其他站點。 中型站點:多個網站共用一個應用池,比如5個站點用一個池,設定他資源時間等等。這樣他們就算超資源了也不影響其他應用池的網站。

6:設定回收時間:很多人以為設定回收池越短越好,其實是錯誤的,每次回收當然是把記憶體回收回來了,但加重了一次伺服器的負擔,當伺服器比較繁忙的時候,有可能導緻其他應用池死。是以建議設定共1000就行了。其他獨立池按照他網站流量而設定 可以設定600 也行,共用的不建議設定太

本文轉自 佛哒 51CTO部落格,原文連結:http://blog.51cto.com/fodaa/1731615,如需轉載請自行聯系原作者