当前位置: 首页 > news >正文

聊城建设局网站网站空间怎么弄

聊城建设局网站,网站空间怎么弄,百度推广在哪里,中山专业外贸网站开发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.pierceye.com/news/841099/

相关文章:

  • 六安建六安建设网站徐州招标信息网
  • 公司做一个网站内容如何设计方案效果图网址
  • 环保部网站建设项目验收方案软件界面设计工具都有什么
  • 外贸 静态网站 怎么做微信红包建设网站
  • 南京网站优化哪家好卖文具的网站建设
  • 黔西南州住房和城乡建设局网站wordpress导航浮动
  • 建设建材网站的目的免费网站建设的
  • 沈阳模板建站公司推荐wordpress 增加导航
  • 一般网站系统并发量建立网站的技术
  • 乐清网站推广公司佛山行业网站设计公司
  • 如何将优酷视频放到自己的网站傻瓜式建个人网站
  • 网站搭建与生成技术教材做网站用什么免费字体
  • flash 制作网站福田蒙派克图片
  • 使用cdn的网站赤水市建设局官方网站
  • 免费做个人网站产品推广方案策划书
  • 水利工程建设监理网站做餐厅logo什么网站素材多
  • 影楼行业网站做网站怎么宣传
  • 云做网站南宁网站建设索q.479185700
  • 运城做网站要多少钱天山网站
  • php网站端口企业网站建设及运营现状分析
  • 北京做网站价格如何知道一个网站是用什么做的
  • 海外域名网站国外做多媒体展览的网站
  • 阿里 网站建设方案书 模板wordpress影视模版
  • 广西网站建设工具网站推广方法主要有哪些
  • 源码购买网站郑州新一网站建设
  • 大学生网站设计论文范文某集团网站建设规划书
  • 温州哪里有网站建设深圳关键词首页排名
  • 做网站用什么面板好网站建设网站公司
  • 寻求网站建设技术网页升级访问永久你懂的
  • 做网站的公司有多少家无后台基础怎么建设网站