性能测试之JVM的故障排查-死锁

发表于:2020-7-29 11:42

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:bestDD    来源:大道测试

  死锁原因
  Java发生死锁的根本原因是:在申请锁时发生了交叉闭环申请。即线程在获得了锁A并且没有释放的情况下去申请锁B,这时,另一个线程已经获得了锁B,在释放锁B之前又要先获得锁A,因此闭环发生,陷入死锁循环。
  监控死锁
  VisualVM监控工具有明显线程死锁提醒,也可监控到发生死锁的线程、类、代码行数、数据类型。
  分析死锁
  1.VisualVM生成threaddump,查找死锁代码块内存地址
  2.VisualVM生成heapdump, 使用OQL查看被死锁对象的值和引用
 select heap.findObject("0x00000006c0276428")
  

   3.使用OQL的另一种方法
   jmap -dump:live,file=/data/test.map <jps端口号>
  jhat /data/test.map
  浏览器访问 http://ip:7000/

  示例代码
   /*
  * 线程死锁等待演示
  */
  static class SynAddRunalbe implements Runnable {
  int a, b;
  public SynAddRunalbe(int a, int b) {
  this.a = a;
  this.b = b;
  }
  @Override
  public void run() {
  synchronized (Integer.valueOf(a)) {
  synchronized (Integer.valueOf(b)) {
  System.out.println(a + b);
  }
  }
  }
  public static void main(String[] args) throws Exception {
  for (int i=0;i< 100; i++) {
  new Thread(new SynAddRunalbe(1, 2)).start();
  new Thread(new SynAddRunalbe(2, 1)).start();
  }
  }

      本文内容不用于商业目的,如涉及知识产权问题,请权利人联系51Testing小编(021-64471599-8017),我们将立即处理
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号