公司後台查詢資料時,如果選擇的時間段過長,就會遇到"請求逾時"的的問題。
造成這一問題的原因大概有以下幾點:
1,Asp.net請求逾時
2,Webservice請求逾時
3,IIS請求逾時
4,資料庫連接逾時
知道原因後,就可以解決問題了。
Asp.net中關於逾時的設定:
在web.config 裡<system.web>節點添加以下代碼:
[csharp] [/csharp]
來自MSDN解釋:
httpRuntime是配置asp.Net http運行時設定,以確定如何處理對asp.Net應用程式的請求。
executionTimeout:表示允許執行請求的最大時間限制,單位為秒 maxRequestLength:指示 ASP.Net 支援的最大檔案上傳大小。該限制可用於防止因使用者將大量檔案傳遞到該伺服器而導致的拒絕服務的攻擊。指定的大小以 KB 為單位。預設值為 4096 KB (4 MB)。
WebService請求逾時時間的設定:
擴大代理類的逾時限制,預設是90秒 ,即在調用方法前指定逾時時間。
[csharp]YourWebService yws = new YourWebService(); yws.Timeout = 1200000; //20分鐘,單位是毫秒[/csharp]
如果將 Timeout 屬性設定為 Timeout.Infinite,則指示該請求無逾時。即使 XML Web services 用戶端可以將 Timeout 屬性設定為無逾時,Web 服務器仍可以在伺服器端使請求逾時。
IIS中請求逾時設定。
IIS-網站-屬性 連線逾時時間 1200秒
資料庫連接(ado.net)逾時
1,可能是串連池(Connection Pooling)中的連結用完了,需要擴大串連池。
2,給sqlcommand設定一個更長的逾時時間(timeout屬性)。
[csharp] SqlCommand myCommand = new SqlCommand(); myCommand.CommandTimeout = 15; [/csharp]
3,ado.net逾時比較複雜,還可能是表被鎖定或者其他的別的原因。
題後:其他開發平台(jsp,php)中“請求逾時”問題的解決應該有類似的方法。例如設定apche,tomcat的逾時時間更長些。
此文同時發布在:http://www.2evening.info/archives/asp-net-webservice-timeout.html