加入收藏 | 设为首页 | 会员中心 | 我要投稿 北几岛 (https://www.beijidao.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。

发布时间:2021-05-20 14:34:50 所属栏目:大数据 来源: https://blog.csdn.net/kasama1
导读:近来遇到这样一个错误:Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。错误截图如下: 错误原因分析: 产生错误时我执行的操作需要的执行时间比较长。我测试了一下,那个操作用到的存储过程,需要处理的数据有13多万条,需要执行时间大概是1

近来遇到这样一个错误:Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应。错误截图如下:

错误原因分析:
产生错误时我执行的操作需要的执行时间比较长。我测试了一下,那个操作用到的存储过程,需要处理的数据有13多万条,需要执行时间大概是1分40秒。下图是当时执行时的截图。

而客户端与数据库连接时间以及命令的执行时间都是有限的,当这两个时间其中一个小于操作时间,错误就会产生。

解决方法:
第一步:修改Web.config配置文件。在数据库连接字符串中加上连接时间Connect Timeout,根据实际情况定时间。

  1. <!--连接数据库-->??
  2. <connectionStrings>??
  3. ?????<add?name="strConnDB"?connectionString="?Data?Source=192.168.*.*;Initial?Catalog=DatabaseName;Persist?Security?Info=True;User?id=sa;Password=password;pooling=true;max?pool?size=800;min?pool?size=300;<span?style="color:#FF0000;">Connect?Timeout=500</span>;"/>??
  4. </connectionStrings>??


第二步:修改command对象的CommandTimeout属性。?

    sqlCommand?cmd?=?new?sqlCommand();??
  1. cmd.CommandTimeout?=?180;??

这里设置的时间是180秒,即三分钟!可根据需要设置,如果过长,也可以设置为0,当此属性设置为0时表示不限制时间。此属性值应该慎用。

到此为止,问题完美解决。

补充:
sqlCommand.CommandTimeOut:获取或设置在终止执行命令的尝试并生成错误之前的等待时间。
sqlConnection.ConnectionTimeout:获取在尝试建立连接时终止尝试并生成错误之前所等待的时间。

(编辑:北几岛)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读