记一次 .NET某hdp智能柜系统 卡死分析

💡 原文中文,约10100字,阅读约需24分钟。
📝

内容提要

文章讲述了作者因狗咬、购房和孩子跳绳比赛而感到焦虑。随后,作者分析朋友程序的卡死问题,使用WinDbg工具检查主线程和GC,最终发现是线程死循环导致GC无法暂停,建议通过增加Thread.Sleep来解决。

🎯

关键要点

  • 作者因狗咬、购房和孩子跳绳比赛而感到焦虑。
  • 作者分析朋友程序的卡死问题,使用WinDbg工具检查主线程和GC。
  • 发现是线程死循环导致GC无法暂停,建议通过增加Thread.Sleep来解决。
  • 作者在经历狗咬后打了狂犬疫苗,感到焦虑。
  • 为孩子选择教育资源丰富的学校而感到焦虑,经过实地考察后解决了问题。
  • 孩子参加市级跳绳比赛,导致作者睡眠不足,精神状态不佳。
  • 通过分析主线程调用栈,发现主线程在等待GC完成。
  • 通过观察线程调用栈,发现是3号线程挂了GC相关函数SuspendEE。
  • GC正处于SuspendEE阶段,导致线程无法暂停。
  • 使用脚本搜索托管线程地址,发现58号线程处于协作状态。
  • 58号线程的代码中存在死循环,导致GC无法暂停。
  • 建议通过增加Thread.Sleep来解决线程问题,或升级coreclr版本。
➡️

继续阅读