超時(shí)時(shí)間已到。在操作完成之前超時(shí)時(shí)間已過(guò)或服務(wù)器未響應(yīng)
2008-01-09 21:02
http://hi.baidu.com/vvjms報(bào)錯(cuò),“超時(shí)時(shí)間已到。在操作完成之前超時(shí)時(shí)間已過(guò)或服務(wù)器未響應(yīng)”
初步分析原因?yàn)閷?duì)MSSQL操作時(shí)連接超時(shí),知道這事,以前沒(méi)留意,大概是在配置文件中設(shè)置連接時(shí)限,在網(wǎng)上找了下解決方法,大多說(shuō)在數(shù)據(jù)庫(kù)連接字符串里解決
SqlConnection con = new SqlConnection'server=.;database=myDB;uid=sa;pwd=password;'
改為:
SqlConnection con = new SqlConnection'server=.;database=myDB;uid=sa;pwd=password;Connect Timeout=500'
似乎沒(méi)效果。依然運(yùn)行30秒即報(bào)超時(shí)!
突然感覺(jué)似乎應(yīng)該可以在連接數(shù)據(jù)庫(kù)代碼中指明,式了下con的屬性,有個(gè)ConnectionTimeout,
SqlConnection con = new SqlConnection'server=.;database=myDB;uid=sa;pwd=;';
con.ConnectionTimeout = 180;//報(bào)錯(cuò),屬性ConnectionTimeout 為只讀!
嘗試失敗,再接著看command對(duì)象屬性,發(fā)現(xiàn)其也有類(lèi)似屬性!CommandTimeout設(shè)置一下:
SqlCommand cmd = new SqlCommand;
cmd.CommandTimeout = 180;
再運(yùn)行,即解決,這里設(shè)置的時(shí)間的180秒,即三分鐘!可根據(jù)需要設(shè)置,如果過(guò)長(zhǎng),也可以設(shè)置為0,當(dāng)此屬性設(shè)置為0時(shí)表示不限制時(shí)間。此屬性值應(yīng)該慎用。還需要在Web.config配置文件中設(shè)置http請(qǐng)求運(yùn)行時(shí)限間
<system.web>
<httpRuntime maxRequestLength='102400' executionTimeout='720' />
</system.web>
這里設(shè)置的為720秒,前面的屬性maxRequestLength一般用于用戶(hù)上傳文件限制大?。∧J(rèn)一般為4096 KB 4 MB。
看一下來(lái)自MSDN解釋?zhuān)?div style="height:15px;">
httpRuntime是配置asp.net http運(yùn)行時(shí)設(shè)置,以確定如何處理對(duì)asp.net應(yīng)用程序的請(qǐng)求。
executionTimeout:表示允許執(zhí)行請(qǐng)求的最大時(shí)間限制,單位為秒
maxRequestLength:指示 ASP.NET 支持的最大文件上載大小。該限制可用于防止因用戶(hù)將大量文件傳遞到該服務(wù)器而導(dǎo)致的拒絕服務(wù)攻擊。指定的大小以 KB 為單位。默認(rèn)值為 4096 KB 4 MB。
useFullyQualifiedRedirectUrl:表示指示客戶(hù)端重定向是否是完全限定的(采用 '
http://server/path' 格式,這是某些移動(dòng)控件所必需的),或者指示是否代之以將相對(duì)重定向發(fā)送到客戶(hù)端。如果為 True,則所有不是完全限定的重定向都將自動(dòng)轉(zhuǎn)換為完全限定的格式。false 是默認(rèn)選項(xiàng)。
minFreeThreads:表示指定允許執(zhí)行新請(qǐng)求的自由線(xiàn)程的最小數(shù)目。ASP.NET 為要求附加線(xiàn)程來(lái)完成其處理的請(qǐng)求而使指定數(shù)目的線(xiàn)程保持自由狀態(tài)。默認(rèn)值為 8。
minLocalRequestFreeThreads:表示ASP.NET 保持的允許執(zhí)行新本地請(qǐng)求的自由線(xiàn)程的最小數(shù)目。該線(xiàn)程數(shù)目是為從本地主機(jī)傳入的請(qǐng)求而保留的,以防某些請(qǐng)求在其處理期間發(fā)出對(duì)本地主機(jī)的子請(qǐng)求。這避免了可能的因遞歸重新進(jìn)入 Web 服務(wù)器而導(dǎo)致的死鎖。
appRequestQueueLimit:表示ASP.NET 將為應(yīng)用程序排隊(duì)的請(qǐng)求的最大數(shù)目。當(dāng)沒(méi)有足夠的自由線(xiàn)程來(lái)處理請(qǐng)求時(shí),將對(duì)請(qǐng)求進(jìn)行排隊(duì)。當(dāng)隊(duì)列超出了該設(shè)置中指定的限制時(shí),將通過(guò)“503 - 服務(wù)器太忙”錯(cuò)誤信息拒絕傳入的請(qǐng)求。
enableVersionHeader:表示指定 ASP.NET 是否應(yīng)輸出版本標(biāo)頭。Microsoft Visual Studio 2005 使用該屬性來(lái)確定當(dāng)前使用的 ASP.NET 版本。對(duì)于生產(chǎn)環(huán)境,該屬性不是必需的,可以禁用。