程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> Asp.Net各種超時問題總結

Asp.Net各種超時問題總結

編輯:ASP.NET基礎
 
   在數據庫或者請求操作時,如果選擇的時間段過短或操作數據量過大,就會遇到"請求超時"的的問題,網絡上提供很多解決方案,但普遍不完善,根據個人經驗及參考網絡解決方案,先將其匯總如下:

    根據錯誤類型,大致分為如下幾種情況
  1:Asp.net請求超時
  2:IIS請求超時
  3:數據庫連接超時
  4: 數據庫操作超時
  5:應用程序池回收(低)
  6:Webservice等服務請求超時 

下面根據上述情況一一作出處理
1:Asp.net請求超時
  http請求超時可以在webconfig中進行全局配置,(單位為秒,默認為90秒)如下
    <system.web> 
     <httpRuntime maxRequestLength="102400" executionTimeout="180" /> 
    system.web>

2:IIS請求超時
  直接去IIS進行設置:IIS-網站-屬性   設置一個較大的值,但是不能太大,具體情況具體分析。

3:數據庫連接超時
  在配置數據庫連接字符串的時候一起配置
  <connectionStrings>
    <add name="MarketingMate" connectionString="Data Source=192.168.1.1; Database=MarketingMate; User Id=sa; Password=123; Connect Timeout=30;Min Pool Size=16;Max Pool Size=100;"
       providerName="System.Data.SqlClient"/>   
  connectionStrings>

4. 數據庫操作超時
  數據庫操作超時目前還沒有全局設置方法,只能設置Command類的CommandTimeOut屬性(單位為秒,默認為30秒)
   context.CommandTimeout = 180; 

 5:應用程序池回收(底)這種出現的情況很低,請酌情設置
  應用程序池會在一定的時間內回收線程,直接設置即可:應用程序池--屬性--回收工作進程

 6:Webservice等服務請求超時 (這種是參考網上提供的解決方法,本人沒遇到過)
  擴大代理類的超時限制,默認是90秒  ,即在調用方法前指定超時時間。
  [csharp]YourWebService yws = new YourWebService(); yws.Timeout = 1200000; //20分鐘,單位是毫秒[/csharp]
  如果將 Timeout 屬性設置為 Timeout.Infinite,則指示該請求無超時。即使 XML Web services 客戶端可以將 Timeout 屬性設置為無超時,Web 服務器仍可以在服務器端使請求超時。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved