加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-15 17:28:41 所属栏目:百科 来源:网络整理
导读:我正在使用由WCF服务支持的ASP.NET站点,其中服务随机抛出异常,最终在站点上捕获,并在那里创建YSOD.我怀疑这是由于后端的线程问题,并希望跟踪问题. 是否有一种简单的方法可以捕获WCF端的未捕获异常,并捕获所有运行的线程的堆栈跟踪,并使用其他信息重新抛出初
我正在使用由WCF服务支持的ASP.NET站点,其中服务随机抛出异常,最终在站点上捕获,并在那里创建YSOD.我怀疑这是由于后端的线程问题,并希望跟踪问题.

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

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

解决方法

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

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

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

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读