做模具行业的网站wordpress怎么找模板
news/
2025/10/3 13:20:45/
文章来源:
做模具行业的网站,wordpress怎么找模板,国际军事新闻最新消息今天,建设网站业务竞争大Tags : jstack日志发表时间#xff1a;2019-03-17 23:53:19在分析线上问题时常使用到jstack 命令将当时Java应用程序的线程堆栈dump出来。面对jstack 日志#xff0c;我们如何查看#xff1f;首先要清楚线程的状态线程的状态有#xff1a;new、runnable、running、waiting、…Tags : jstack日志发表时间2019-03-17 23:53:19在分析线上问题时常使用到jstack 命令将当时Java应用程序的线程堆栈dump出来。面对jstack 日志我们如何查看首先要清楚线程的状态线程的状态有new、runnable、running、waiting、timed_waiting、blocked、dead线程状态变迁图各状态说明New: 当线程对象创建时存在的状态此时线程不可能执行Runnable当调用thread.start()后线程变成为Runnable状态。只要得到CPU就可以执行Running线程正在执行Waiting执行thread.join()或在锁对象调用obj.wait()等情况就会进该状态表明线程正处于等待某个资源或条件发生来唤醒自己Timed_Waiting执行Thread.sleep(long)、thread.join(long)或obj.wait(long)等就会进该状态与Waiting的区别在于Timed_Waiting的等待有时间限制Blocked如果进入同步方法或同步代码块没有获取到锁则会进入该状态Dead线程执行完毕或者抛出了未捕获的异常之后会进入dead状态表示该线程结束其次对于jstack日志我们要着重关注如下关键信息Deadlock表示有死锁Waiting on condition等待某个资源或条件发生来唤醒自己。具体需要结合jstacktrace来分析比如线程正在sleep网络读写繁忙而等待Blocked阻塞 Waiting on monitor entry在等待获取锁in Object.wait()获取锁后又执行obj.wait()放弃锁对于Waiting on monitor entry 和 in Object.wait()的详细描述Monitor是 Java中用以实现线程之间的互斥与协作的主要手段它可以看成是对象或者 Class的锁。每一个对象都有也仅有一个 monitor。从下图中可以看出每个 Monitor在某个时刻只能被一个线程拥有该线程就是 Active Thread而其它线程都是 Waiting Thread分别在两个队列 Entry Set和 Wait Set里面等候。在 Entry Set中等待的线程状态是 Waiting for monitor entry而在 Wait Set中等待的线程状态是 in Object.wait()最后通过示例来实践一下示例一描述 Blocked 和 Waiting to lock执行后程序输出Thread[main,5,main]说明主线程先进入同步代码块获取到thread2对象上的锁。通过jstack输出结果先说明下日志格式thread2为线程名称在平时创建线程或线程池时请务必取一个见明之义的线程名称方便排查问题prio6线程优先级不用关心tid0x0000000006540800线程id不用关心nid0x2be4操作系统映射的线程id, 非常关键后面再使用jstack时补充waiting for monitor entry表示线程正在等待获取锁0x0000000006dbf000线程栈起始地址从jstack日志中可以看到主线程获取到thread2对象上的锁因此正在执行sleep操作状态为TIMED_WAINTING, 而thread2由于未获取到thread2对象上的锁因此处于BLOCKED状态。再细看thread2 正在waiting to lock 0x00000000d719d280即试图在地址为0x00000000d719d280所在的对象获取锁而该锁却被main线程占有(locked 0x00000000d719d280)。main线程正在waiting on condition说明正在等待某个条件触发由jstacktrace来看此线程正在sleep。经验如果在jstack日志发现大量的线程在waiting to lock 某个地址只要能查到哪个线程获取到锁就可以方便定位问题了示例二描述waiting on condition]jstack日志输出结果从日志中可以看到main线程的状态是Waiting正在waiting on condition来唤醒自己。结合jstackstrace日志来看parking to wait for 0x00000000d719ba70 (a java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject)说明在调用ArrayBlockingQueue.put()阻塞了。示例三描述Object.wait()程序输出结果Thread[thread2,5,main]Thread[main,5,main]说明线程thread2先进入同步代码块获取到thread2对象上的锁。jstack日志输出结果可以看出线程thread2的状态是Waiting, 正在in Object.wait()。表明该线程在获取到对象锁后调用obj.wait()方法放弃了锁进入了Wait Set队列。...阅读原文
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/925939.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!