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

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

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

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

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

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

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

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

转载注明原文:c# – 在抛出异常时捕获所有线程的堆栈跟踪 - 代码日志