【问题标题】:Is there a way to check connections in pool from C# code?有没有办法从 C# 代码检查池中的连接?
【发布时间】:2011-07-20 17:02:00
【问题描述】:

我正在开发一个混淆工具,它基本上在专用 SQL 服务器(仅用于此工具)上敲击数据库,以检索记录、执行一些数据操作,然后更新这些记录。这一切都是通过 LINQ to SQL 完成的。我正在使用任务和并行循环来同时运行尽可能多的更新。所有 SQL 都是从同一个连接字符串完成的。最初我使用默认的最大连接池大小(100)假设它就足够了。似乎在运行了几个小时后(因为这个工具正在更新数百万条记录),它开始呕吐,因为它无法建立连接。在查看连接池后,我注意到我已经达到了 100 的限制。因此我将限制增加到 200。这工作得更好但是我的一个进程(没有提到这在几个进程中运行)结束了大约3小时后失败。连接池似乎没有被过度使用,因此我只能摸不着头脑。我检查了我的代码中的许多区域,以确保所有连接都被处理,它们就是这样。我什至将所有连接代码移动到一个中心位置,所以现在代码只从一个位置建立连接。为了排除连接池被最大化的想法,我想使用 C# 来查询池以查看尝试连接时出现异常的限制。这可能吗?框架是否有代码来执行此操作,或者我是否需要运行 SQL stmt 来确定这一点?

仅供参考:我使用的是 4.0 和 SQL 2008。

提前致谢!

【问题讨论】:

    标签: sql-server-2008 c#-4.0


    【解决方案1】:

    看起来我可以使用 PerfMon 来监控连接池。这表明我实际上达到了池限制,令我惊讶的是,池并不是我想象的那样设置的 200。问题解决了!有时,我们创建了如此复杂的代码,导致我们自己的问题!

    附注 - 我最初使用的是 sp_who2,但是当我发生异常时,池已被清理,因此我无法获得准确的读数。

    【讨论】:

      猜你喜欢
      • 2017-04-27
      • 1970-01-01
      • 2018-11-18
      • 1970-01-01
      • 1970-01-01
      • 2021-09-26
      • 1970-01-01
      • 2022-01-17
      • 2021-04-11
      相关资源
      最近更新 更多