抛出异常时捕获所有线程的堆栈跟踪

时间:2012-08-29 11:45:22

标签: c# .net multithreading wcf exception

我正在使用由WCF服务支持的ASP.NET站点,其中服务随机抛出异常,最终在站点上捕获,并在那里创建YSOD。我怀疑这是由于后端的线程问题,并希望跟踪问题。

是否有一种简单的方法可以捕获WCF端的未捕获异常,并捕获所有运行的线程的堆栈跟踪,并使用其他信息重新抛出初始异常?

这个多线程跟踪似乎是框架附带的东西,或者其他人之前可能已经考虑过的东西,但我似乎无法找到任何东西。

1 个答案:

答案 0 :(得分:2)

为了捕获其他线程的堆栈跟踪,您必须在调试器中并在抛出异常时查看其堆栈(例如,使用并行堆栈窗口),但这不允许您发送它们的回溯。

你可以检测你的代码(即在战略位置加胡椒)来记录其他线程可以获得的堆栈跟踪,但这会产生令人讨厌的性能,维护和优雅问题。更不用说它只会接近其他线程正在做的事情,因为它们可以在抛出异常后独立进行。

我能想到的唯一另一种方式(这是猜想)是以某种方式中止其他线程,捕获中止,保存堆栈跟踪,然后重置中止。但这可能是一个非确定性的混乱。中止不是推荐的做法。

您可能最好使用呼叫分析器,慷慨的日志记录,并尽可能缩小范围以找到根本原因。