Windbg - 在SNIReadSyncOverAsync上冻结进程但未找到死锁

时间:2017-05-11 05:13:52

标签: deadlock windbg sqldatareader

我有一个奇怪的问题。使用GetValue()函数上的System.Data.SqlClient.SqlDataReader读取数据时进程被冻结/卡住。我正在使用WinDbg分析进程转储。我使用了!dlk!SyncBlk!analyze -v -hang等SOS命令,但没有一个指示任何死锁。

最后一次调用callstack是

000000001a98e8a8 0000000076febd7a [InlinedCallFrame: 000000001a98e8a8] .**SNIReadSyncOverAsync**(SNI_ConnWrapper*, SNI_Packet**, Int32)
000000001a98e8a8 000007fee9e8bca1 [InlinedCallFrame: 000000001a98e8a8] .SNIReadSyncOverAsync(SNI_ConnWrapper*, SNI_Packet**, Int32)
000000001a98e880 000007fee9e8bca1 DomainBoundILStubClass.IL_STUB_PInvoke(SNI_ConnWrapper*, SNI_Packet**, Int32)
000000001a98e950 000007fee9e7254f SNINativeMethodWrapper.SNIReadSyncOverAsync(System.Runtime.InteropServices.SafeHandle, IntPtr ByRef, Int32)
000000001a98e9c0 000007fee9e7226e System.Data.SqlClient.TdsParserStateObject.ReadSniSyncOverAsync()
000000001a98ea70 000007fee9e72180 System.Data.SqlClient.TdsParserStateObject.TryReadNetworkPacket()
000000001a98eab0 000007fee9e72950 System.Data.SqlClient.TdsParserStateObject.TryPrepareBuffer()
000000001a98eae0 000007fee9e728d8 System.Data.SqlClient.TdsParserStateObject.TryReadByteArray(Byte[], Int32, Int32, Int32 ByRef)
000000001a98eb50 000007feea4c0adc System.Data.SqlClient.TdsParser.TryReadSqlValue(System.Data.SqlClient.SqlBuffer, System.Data.SqlClient.SqlMetaDataPriv, Int32, System.Data.SqlClient.TdsParserStateObject)
000000001a98ec10 000007fee9e85cb5 System.Data.SqlClient.SqlDataReader.TryReadColumnInternal(Int32, Boolean)
000000001a98ecb0 000007fee9e85af0 System.Data.SqlClient.SqlDataReader.TryReadColumn(Int32, Boolean, Boolean)
000000001a98ed20 000007fee9e85a0b System.Data.SqlClient.SqlDataReader.GetValueInternal(Int32)
000000001a98ed60 000007fee9e859b7 System.Data.SqlClient.SqlDataReader.GetValue(Int32)

这里有进一步调试的其他途径吗?是否有人面临与SqlDataReader相同的问题?

我最近发现当找到这种堆栈跟踪时,转储中总会出现Win32错误。

0:009> !GLE LastErrorValue:(Win32)0x3e5(997) - 重叠的I / O操作正在进行中。 LastStatusValue:(NTSTATUS)0xc0000034 - 找不到对象名称。

这是否意味着它因某些基础IO操作而被阻止?

0 个答案:

没有答案