精华区 [关闭][返回]

当前位置:月光软件>>讨论区精华>>〖软件开发〗>>● ASP>>★ASP的技巧★>>安全问题>>ASP中有关timeout超时的体会

主题:ASP中有关timeout超时的体会
发信人: maxuejing10(☆绝情★狂煞)
整理人: dongbao(2002-04-19 17:08:45), 站内信件
最近用ASP和MSSQL做了一个数据库应用, 
开始一切顺利,但随着数据量的增加, 
先后几次查询时出现timeout的问题. 
参考Option Pack文档及社区内的文章, 
现在问题都已解决(至少没又发现新的). 

现把解决方法总结一下: 

影响服务器产生超时的设置大致有: 
1. Server.ScriptTimeout, 
2. Connection对象的CommandTimeOut属性, 
3. Command对象的CommandTimeOut属性, 
4. IE浏览器的设置. 

Server.ScriptTimeout,默认值是90秒. 
要增大它,在你的asp文件中加一句,如下: 
Server.ScriptTimeout=999, 
将页面超时设为999秒. 

最初我只设置Server.ScriptTimeout, 
但仍会出现timeout错误,无论它的值设成都多大. 
后在社区里看到一帖子,提到commandTimeout属性, 
于是查看Option Pack文档,果然还有其他的timeout. 

Connection对象和Command对象都有个CommandTimeOut属性, 
默认是30秒,如果你有一个耗时的查询或数据处理, 
很容易就超时了.要增大它,也很容易,创建对象后, 
设置它的属性,如下: 
con.CommandTimeOut = 999, 
设为999秒,其中con是一Connection对象. 
如设为零,将无限等待,没有这一timeout限制. 

Command对象不会继承Connection的这一属性, 
所以对可能超时的Command也要单独设置CommandTimeout属性. 

最后IE也有个超时设置,5分钟从服务器得不到数据,也超时. 
这种情况可能很少碰到, 
但当我把一10多万查询的结果保存为mdb文件时, 
就遇到了.(至于保存的方法,请参看精华区中的一篇帖子.) 
解决方法:(原文请参照微软KB中的Q181050) 
1. IE要4.01 sp1以上版本. 
2. 在注册表中HKEY_CURRENT_USER\Software\Microsoft\ 
Windows\CurrentVersion\Internet Settings中 
加一DWORD类型ReceiveTimeout,值设为比如8个9. 
3. restart computer. 



[关闭][返回]






转载请注明:转载自 月光程序代码网 [ http://www.moon-soft.com ]