Java故障定位方法总结

 

  • 多线程并发,程序执行速度较快,使用简单断点不能够定位到出错的线程;
    •   通过打印日志,不断精确定位故障的位置和导致故障的原因。
    • 在断点处设置condition为Thread.currentThread().getName().contains("目标线程池的名字");
  • 线程池之间的任务调度,导致堆栈较短。
    •   分析多个线程池级联调用的顺序关系,分析线程池任务的相互转换关系。
    某个程序可能会被不同的接口进行调用。
    •   在出错的位置,生成IllegalArgumentException(),使用logger.error(e)打印堆栈信息到日志,分析堆栈信息,找到引起故障的调用接口。
  • 程序不断创建新的线程池,已知该线程池的名字,对程序不熟悉
    •   在日志中搜索该线程池,找到线程池打印的日志,到代码中搜索该日志,找到打印日志的位置。

 

转载于:https://www.cnblogs.com/MyLifeMyWay/p/8481911.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值