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

asp.net-mvc – “信号量超时期限已过期”SQL Azure

发布时间:2020-12-16 00:06:38 所属栏目:asp.Net 来源:网络整理
导读:我正在运行一个.Net MVC Azure网站,其中包含使用Entity Framework 6访问的SQL Azure数据库.间歇性地(大约一千个请求中的一个),我收到错误“System.ComponentModel.Win32Exception:信号量超时期限已过期” System.Data.SqlClient.SqlException: A transport-
我正在运行一个.Net MVC Azure网站,其中包含使用Entity Framework 6访问的SQL Azure数据库.间歇性地(大约一千个请求中的一个),我收到错误“System.ComponentModel.Win32Exception:信号量超时期限已过期”

System.Data.SqlClient.SqlException: A transport-level error has
occurred when receiving results from the server. (provider: TCP
Provider,error: 0 – The semaphore timeout period has expired.) —>
System.ComponentModel.Win32Exception: The semaphore timeout period has
expired

似乎没有理由在错误之前和之后以及它们与SQL Azure的交互都很好.有没有办法处理或解决这个问题.

解决方法

Azure SQL与内部SQL非常不同.当Azure SQL Server过载或关闭时,它将断开许多连接,当您重新连接时,您将被发送到另一个SQL Server.

但是,对于TCP连接,您不知道另一端是否已终止连接,除非您实际向下发送信息,这就是发生此错误的原因.

一旦你的代码知道连接被终止,它就会在下一个查询上建立一个新的连接,这将很好地工作.

使用Entity Framework 6,您现在可以处理Transient Fault Handling with SQL Azure using Entity Framework

在DBConfiguration类中,您需要设置SetExecutionStrategy并对其进行配置.只需在项目中创建一个新类,并从DbConfiguration继承.

public class MyConfiguration : DbConfiguration 
{ 
    public MyConfiguration() 
    { 
        SetExecutionStrategy( 
            "System.Data.SqlClient",() => new SqlAzureExecutionStrategy(1,TimeSpan.FromSeconds(30))); 
    } 
}

详情请见Connection Resiliency / Retry Logic (EF6 onwards)

(编辑:李大同)

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

    推荐文章
      热点阅读