(摘)timeoutTimeout时间已到.在操作完成之前超时时间已过或服务器未响应的
⼏种情况
Timeout时间已到.在操作完成之前超时时间已过或服务器未响应
问题
在使⽤asp开发的应⽤程序查询数据的时候,遇到页⾯请求时间过长且返回"Timeout时间已到。在操作完成之间超时时间已过或服务器未响应"的情况
分析
造成这⼀问题的原因⼤概有以下⼏点:
1.Asp请求超时
2.Webservice请求超时
3.IIS请求超时
4.数据库连接超时
数据库连接超时
连接字符串中添加Connect Timeout
在数据库连接字符串后⾯添加Connect Timeout=500(连接超时时间设为500秒)
SqlConnection con = new SqlConnection("server=.;database=myDB;uid=sa;pwd=password;Connect Timeout=500")
运⾏查询后,不到30秒,仍然返回Timeout超时,问题未解决
设置Command对象属性CommandTimeout
SqlCommand cmd = new SqlCommand();
cmd.CommandTimeout = 180;
运⾏,可以解决Command的执⾏超时问题,这⾥设置的时间的180秒,可根据需要设置,如果过长,也可设置为0,设置为0时表⽰不限制时间,此属性值需慎⽤。还需要在
<system.web>
<httpRuntime maxRequestLength="102400" executionTimeout="720" />
</system.web>
这⾥设置的为720秒,前⾯的属性maxRequestLength⼀般⽤于⽤户上传⽂件限制⼤⼩!默认⼀般为4096 KB (4 MB)。
设置 DataAdapter对象属性SelectCommand
SqlDataAdapter da = new SqlDataAdapter(strsqll, sqlconstr);
da.SelectCommand.CommandTimeout = 180;
运⾏,解决超时问题。该条设置对DataAdapter返回多条记录查询超时问题的解决效果⽴竿见影(Repeater绑定数据多适⽤次情况)。设置时间为180秒,根据需要可更改。
Asp中关于超时的设置
在fig ⾥<system.web>节点添加以下代码:
调用webservice服务<system.web>
<httpRuntime maxRequestLength="102400" executionTimeout="720" />
</system.web>
MSDN解释:
httpRuntime是配置asp.Net http运⾏时设置,以确定如何处理对asp.Net应⽤程序的请求。
executionTimeout:表⽰允许执⾏请求的最⼤时间限制,单位为秒 maxRequestLength:指⽰ ASP.Net ⽀持的最⼤⽂件上载⼤⼩。该限制可⽤于防⽌因⽤户将⼤量⽂件传递到该服务器⽽导致的拒绝服务攻击。指定的⼤⼩以 KB 为单位。默认值为 4096 WebService请求超时时间的设置:
扩⼤代理类的超时限制,默认是90秒,即在调⽤⽅法前指定超时时间。
YourWebService yws = new YourWebService(); yws.Timeout = 1200000; //20分钟,单位是毫秒
如果将 Timeout 属性设置为 Timeout.Infinite,则指⽰该请求⽆超时。即使 XML Web services 客户端可以将 Timeout 属性设置为⽆超时,Web 服务器仍可以在服务器端使请求超
时。
IIS中请求超时设置。
IIS-⽹站-属性连接超时时间 1200秒

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。