在資料庫或者請求操作時,如果選擇的時間段過短或操作資料量過大,就會遇到"請求逾時"的的問題,網路上提供很多解決方案,但普遍不完善,根據個人經驗及參考網路解決方案,先將其匯總如下:
根據錯誤類型,大致分為如下幾種情況
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 服務器仍可以在伺服器端使請求逾時。