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

网站主页图片怎么换济南建设学院官网

网站主页图片怎么换,济南建设学院官网,软件开发是学什么,高端的网站设计制作jvmti这篇文章分析了为什么Plumbr Agents在某些情况下以及如何延长GC暂停的时间。 对基本问题进行故障诊断揭示了有关在GC暂停期间如何处理JVMTI标记的有趣见解。 发现问题 我们的一位客户抱怨说#xff0c;附加了Plumbr代理后#xff0c;应用程序的响应速度明显降低。 通过… jvmti 这篇文章分析了为什么Plumbr Agents在某些情况下以及如何延长GC暂停的时间。 对基本问题进行故障诊断揭示了有关在GC暂停期间如何处理JVMTI标记的有趣见解。 发现问题 我们的一位客户抱怨说附加了Plumbr代理后应用程序的响应速度明显降低。 通过分析GC日志我们发现GC时间异常。 这是不带Plumbr的JVM摘录的GC日志 2015-01-30T17:19:08.965-0200: 182.816: [Full GC (Ergonomics) [PSYoungGen: 524800K-0K(611840K)] [ParOldGen: 1102620K-1103028K(1398272K)] 1627420K-1103028K(2010112K), [Metaspace: 2797K-2797K(1056768K)], 0.9563188 secs] [Times: user7.32 sys0.01, real0.96 secs] 这是附加了Plumbr Agent的 2015-02-02T17:40:35.872-0200: 333.166: [Full GC (Ergonomics) [PSYoungGen: 524800K-0K(611840K)] [ParOldGen: 1194734K-1197253K(1398272K)] 1719534K-1197253K(2010112K), [Metaspace: 17710K-17710K(1064960K)], 1.9900624 secs] [Times: user7.94 sys0.01, real1.99 secs] 异常隐藏在经过的时间中。 实时时间是经过的实际时间。 如果您手里拿着秒表那么实时将等于该数字。 用户时间 加上系统时间是测量过程中消耗的总CPU时间。 如果多个内核上有多个线程则该时间可能大于实时时间。 因此对于并行GC实时时间应大致等于用户时间/线程数。 在我的机器上该比率应该接近7而没有Plumbr Agent的情况下确实是如此。 但是使用Plumbr时该比率大大下降。 绝对不行 初步调查 有了这样的证据以下是最可能的假设 Plumbr使JVM在每个GC之后执行一些繁重的单线程操作 Plumbr导致JVM使用更少的线程进行垃圾回收 但是仅查看GC日志中的一行就无法进行更狭窄的观察因此我们继续进行可视化上述比率 图表上的下降恰好发生在Plumbr发现内存泄漏的那一刻。 根本原因分析过程中GC可能会给GC带来一些额外负担但永久影响GC暂停时间绝对不是我们为代理特意设计的功能。 这种行为有利于第一个假设因为我们不太可能在运行时影响GC线程的数量。 创建一个隔离的测试用例花费了一段时间但是在以下约束的帮助下我们可以钉上它 应用程序必须泄漏内存以供Plumbr检测 应用程序必须经常暂停以进行垃圾收集 …以及作为突破时刻–应用程序必须具有较大的活动集这意味着在Full GC中幸存的对象数量必须很大。 编译了足够小的测试用例后可以放大根本原因检测范围。 合理的方法是打开和关闭Plumbr代理的各个功能然后查看问题将在哪种配置下重现。 通过这种简单的搜索我们设法将问题定位到Plumbr Agent执行的单个操作。 JVMTI标记关闭后问题消失了。 在分析gc根和引用链的路径时 我们标记堆上的每个对象。 显然GC时间在某种程度上受我们生成的标签的影响。 寻找根本原因 但是尚不清楚为什么GC暂停会延长。 垃圾会被Swift收集并且大多数带标签的对象应该符合GC的条件。 但是发现的是存在大量活动集这是内存泄漏的症状之一其中保留了许多带标签的对象。 但是即使对活动集中的所有对象都进行了标记这也不应线性影响GC时间。 GC完成后我们会收到有关所有已收集的标记对象的通知但活动集不在这些对象之内。 这使人们想知道HotSpot是否出于某种奇怪的原因在每个GC之后迭代所有标记的对象。 为了验证要求可以查看热点源代码。 经过一番挖掘之后我们最终到达JvmtiTagMap :: do_weak_oops 它的确对所有标签进行了迭代 并对所有标签进行了一些不太便宜的操作。 更糟的是该操作是顺序执行的并且不并行执行。 在每个垃圾回收之后找到调用此方法的调用链之后解决了最后一个难题。 为什么这样做的方式以及它与弱引用的关系完全超出了本文的范围 在并行GC上运行并具有与串行运行相同的昂贵操作一开始似乎是设计缺陷。 第二个想法JVMTI的创建者可能从未期望有人标记所有的堆因此从来没有费心去优化此操作或并行运行它。 毕竟您永远无法预测人们将使用您设计的功能的所有方式因此也许值得检查Hotspot中的GC后活动是否也应该有机会使用现代JVM倾向于使用的所有gazillion内核。可使用。 因此为了解决这个问题我们需要清理不再需要的标签。 修复它就像在我们的JVMTI回调之一中仅添加三行一样容易 if(isGenerated(*tag_ptr)) {*tag_ptr 0;} 瞧一旦分析完成我们几乎和开始时一样出色。 如下面的屏幕截图所示在发现内存泄漏期间仍然存在暂时的性能波动并且在完成内存泄漏分析之后会略有恶化 结语 现在补丁已推出并且解决了Plumbr检测到泄漏后GC暂停时间受到影响的情况。 随意去获取更新的代理以解决性能问题。 作为一个总结我建议您在使用广泛的标签时要格外小心因为“便宜”的标签会堆积在角落的箱子上从而为性能的大幅下降奠定了基石。 为确保您没有滥用标记请翻转– XX TraceJVMTIObjectTagging的诊断选项。 它将使您能够估计标签映射消耗多少本机内存以及堆遍历花费的时间。 翻译自: https://www.javacodegeeks.com/2015/02/jvmti-tagging-can-affect-gc-pauses.htmljvmti
http://www.pierceye.com/news/834654/

相关文章:

  • 网站建设招聘简介应届生求职网站官网
  • 驾校网站建设中国建设银行信用卡中心网站
  • 网站开发中的文档代理网络是什么意思
  • 如何不让百度收录网站网页设计教程文字和图片
  • 深圳网站建设公司哪家最好WordPress文章查询插件
  • 用于网站开发的语言北京专业做网站推广
  • 美工免费素材网站淘宝客cms建站教程
  • 平板上做网站的软件涂料网站建设
  • 做网站导航的wordpress自由度
  • 怎样建外贸网站步骤的英文
  • 网站网上商城建设网站上线详细步骤
  • 有那些网站可以做推广长沙公司排名
  • 怎样申请做p2p融资网站北京做网站一般多少钱
  • 建筑公司网站作用ASP.NET实用网站开发答案
  • 网站建设如何获取客户东莞网络营销销售
  • 郑州平台类网站自建房平面图设计软件
  • 昆明网站运营公司有哪些网页版微信登录二维码
  • 中国最权威的网站排名网上商店系统设计与开发
  • 自己做装修网站需要多少钱太仓建设网站
  • 湘潭做网站电话磐石网络龙岩kk社区
  • 重庆孝爱之家网站建设哪里可以做期货网站平台
  • 建设网站价位视频网站开发防止盗链
  • 制作网站的难度如何提网站建设需求
  • 做网上竞彩网站合法吗找工作用什么平台最好
  • 石家庄模板网站建网站要钱吗 优帮云
  • wap 网站 源码制作手游需要学什么软件
  • 自己做网站怎样挣钱个人网站模板 php
  • 新加坡建设局网站网站建设资料清单
  • 做网站用什么语言制作最安全?网站设计酷站
  • 河南省做网站的公司个人网站可以做电商吗