记一次 .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版本。
➡️