当我运行这个时:
using(SqlConnection connection = new SqlConnection(connectionString)){
await connection.OpenAsync();
}
它卡在 connection.OpenAsync()
行上。
如果我在 Sql Server Management Studio 中查看数据库的事件连接数,就会发现只有一个:可能是此代码使用的连接。因此,我不确定应用程序池的连接是否已用完。
我做错了什么?
最佳答案
问题根本不在于连接。问题是我的线程死锁,搬起石头砸自己的脚。我试图对包含 connection.OpenAsync()
的方法进行同步调用,像这样:
Task task = MyAsyncMethod();
task.Wait();
调用task.Wait()
我阻塞了线程。当await connection.OpenAsync()
返回,该方法的其余部分想要在我刚刚阻止的同一个线程上运行,因此任务永远不会完成并且 task.Wait()
永远不会回来。
解决方案:
因为在我的异步方法中,我没有任何要求我坚持调用它的同一个线程,所以我只是使用 await connection.OpenAsync().ConfigureAwait(false)
,使其在与我用 task.Wait()
阻止的线程不同的线程中运行该方法的其余部分.
关于sql-server - 当没有事件连接时,SqlConnection.OpenAsync() 挂起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26431344/