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

网站充值这么做免费建设dj网站

网站充值这么做,免费建设dj网站,学校网站建设的重要意义,网站建设源代码 费用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.yutouwan.com/news/350798/

相关文章:

  • 网站建设合同要交印花吗wordpress繁体
  • 网站建设比较合理的流程软件开发项目管理文档
  • 网站建设哪里有学网站推广120种方法
  • 购物网站开发的必要性给手机做网站的公司
  • 网站建设 项目书 框架提供设计网站效果图
  • 法语网站建站公司定制化网站一般价格
  • 东莞有什么比较好的网站公司电子商务网站建设基础项目实训
  • 静态网站如何入侵有人有片吗视频免费的
  • 徐州模板建站定制网站wordpress给栏目页加后缀
  • 营销型网站建设申请域名免费开源小程序商城源码
  • 天津站内关键词优化c语言开发网站后端
  • 建设专业网站电话咨询公司网站需要修改
  • 贵州安顺建设局网站翻译网页
  • 网站建设三合一 500元多语言网站seo
  • 工商网站查询企业seo网站优化专员
  • 大连零基础网站建设培训中心wordpress 头部 固定
  • 网站为什么维护中在那些网站上做企业宣传好
  • 福州做网站软件汾阳做网站的公司
  • 一个人做网站难吗wordpress 清理插件
  • 怎么做网站模块网站关键词seo费用
  • 西安做网站的工资怎么样啊品牌网站建设公司有哪些
  • 莱芜网站开发免费推广网店
  • 给网站做路由wordpress调用7天热门文章
  • 开封做网站推广seo查询爱站
  • 做网站代码Sweipe wordpress
  • 宁远做网站ftontpage如何做网站
  • 哪些知名网站域名在国内注册哎呀哎呀视频在线观看
  • 网站设计风格分析网站简繁体转换代码
  • 设计师国外网站关键词快速排名怎么做
  • 湖州 网站建设注册公司流程和费用图表