ASP中有关timeout超时的体会

王朝asp·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

最近用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_USERSoftwareMicrosoft

WindowsCurrentVersionInternet Settings中

加一DWORD类型ReceiveTimeout,值设为比如8个9.

3. restart computer.

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有  導航