我正在使用由WCF服务支持的ASP.NET站点,其中服务随机抛出异常,最终在站点上捕获,并在那里创建YSOD。我怀疑这是由于后端的线程问题,并希望跟踪问题。
是否有一种简单的方法可以捕获WCF端的未捕获异常,并捕获所有运行的线程的堆栈跟踪,并使用其他信息重新抛出初始异常?
这个多线程跟踪似乎是框架附带的东西,或者其他人之前可能已经考虑过的东西,但我似乎无法找到任何东西。
答案 0 :(得分:2)
为了捕获其他线程的堆栈跟踪,您必须在调试器中并在抛出异常时查看其堆栈(例如,使用并行堆栈窗口),但这不允许您发送它们的回溯。
你可以检测你的代码(即在战略位置加胡椒)来记录其他线程可以获得的堆栈跟踪,但这会产生令人讨厌的性能,维护和优雅问题。更不用说它只会接近其他线程正在做的事情,因为它们可以在抛出异常后独立进行。
我能想到的唯一另一种方式(这是猜想)是以某种方式中止其他线程,捕获中止,保存堆栈跟踪,然后重置中止。但这可能是一个非确定性的混乱。中止不是推荐的做法。
您可能最好使用呼叫分析器,慷慨的日志记录,并尽可能缩小范围以找到根本原因。