20

使用 Entity Framework,我昨晚在我的一个应用程序中收到了以下一些异常:

System.Data.EntityException: The underlying provider failed on Commit. ---> 
System.Data.SqlClient.SqlException: Timeout expired.  The timeout period elapsed prior 
to completion of the operation or the server is not responding.     
    at System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection) 
    at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning()     
    at System.Data.SqlClient.TdsParserStateObject.ReadSniError(TdsParserStateObject stateObj, UInt32 error)
    at System.Data.SqlClient.TdsParserStateObject.ReadSni(DbAsyncResult asyncResult, TdsParserStateObject stateObj)
    at System.Data.SqlClient.TdsParserStateObject.ReadNetworkPacket()     
    at System.Data.SqlClient.TdsParserStateObject.ReadBuffer()     
    at System.Data.SqlClient.TdsParserStateObject.ReadByte()     
    at System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler,SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj)     
    at System.Data.SqlClient.TdsParser.TdsExecuteTransactionManagerRequest(Byte[] buffer, TransactionManagerRequestType request, String transactionName, TransactionManagerIsolationLevel isoLevel, Int32 timeout, SqlInternalTransaction transaction, TdsParserStateObject stateObj, Boolean isDelegateControlRequest)
    at System.Data.SqlClient.SqlInternalConnectionTds.ExecuteTransactionYukon(TransactionRequest transactionRequest, String transactionName, IsolationLevel iso, SqlInternalTransaction internalTransaction, Boolean isDelegateControlRequest)     
    at System.Data.SqlClient.SqlInternalConnectionTds.ExecuteTransaction(TransactionRequest transactionRequest, String name, IsolationLevel iso, SqlInternalTransaction internalTransaction, Boolean isDelegateControlRequest)
    at System.Data.SqlClient.SqlInternalTransaction.Commit()     
    at System.Data.SqlClient.SqlTransaction.Commit()
    at System.Data.EntityClient.EntityTransaction.Commit()     
    --- End of inner exception stack trace ---     
    at System.Data.EntityClient.EntityTransaction.Commit()     
    at System.Data.Objects.ObjectContext.SaveChanges(SaveOptions options)     
    at System.Data.Entity.Internal.InternalContext.SaveChanges()     
    at System.Data.Entity.Internal.LazyInternalContext.SaveChanges()

这个错误的有趣之处在于数据实际上已写入数据库。我在 MS 网站上发现了一篇相关帖子,似乎表明这是与网络相关的错误。

我可以使用帮助的几个问题是:

  1. 我有哪些选项可以解决此错误?
  2. 它是否很可能与网络有关,或者数据库可能是嫌疑人?
  3. 如何从代码中判断交易是否真的完成?
  4. 我应该在这个错误上查询数据库以检查是否成功或只是重试事务?
  5. 如果我确实重试了事务,如何使用 Entity Framework 自动完成,或者我只是捕获/重试?
  6. 我应该看哪些其他项目?

提前致谢。

更新

使用Ignite for SQL,我们能够确定来自另一个组的辅助 SQL 进程正在独占 CPU,从而阻止我们的应用程序正常运行。简而言之,我们正在继续添加辅助服务器,以防止两个团队之间的进一步冲突。

这个异常仍然有趣的是事务实际上是成功而不是失败。

4

2 回答 2

1

我敢打赌,来自事务提交命令的成功响应未发送(或发送速度不够快),导致您的代码出现异常。有点疯狂的边缘案例。这种异常并不一定意味着命令的实际执行失败只是发生失败。

同样,如果从 Web 服务调用发送响应时出现问题,也不一定意味着没有应用该调用的任何副作用。

于 2012-05-24T08:52:06.147 回答
0

卢克+1,解释很好。 错误的措辞是不幸的。

System.Data.EntityException: **The underlying provider failed on Commit.** ---> 
System.Data.SqlClient.SqlException: Timeout expired.  The timeout period elapsed prior 

应该读

System.Data.EntityException: **The underlying provider failed to respond to Commit**
System.Data.SqlClient.SqlException: Timeout expired.  The timeout period elapsed prior 

可能的原因是网络或服务器问题。例如 100 CPU,或其他服务器延迟,仍然是正确的。但是你不知道它是否已经提交,如果这是一个超时情况。如果收到失败的响应,则数据库应该已回滚。当然,如果这没有发生,那么数据库已经崩溃并导致潜在的损坏。我希望很少见。

我在一个超过 10 亿行的表中看到......在增长的空间分配过程中,由于索引和数据区域需要扩展,需要 30 多秒。但是 COMMIT 确实发生了。客户端已超时。在线重组也会导致这样的延迟(我至少在 DB2 上看到过)

于 2013-05-11T14:54:18.647 回答