- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有以下 jHiccup 结果。
显然图中有几秒的巨大峰值。我的应用程序每 100 毫秒左右输出一次日志。当我阅读我的日志时,我从未见过如此巨大的停顿。我还可以从 JVM 诊断检查 GC 花费的总时间,它显示如下:
Time:
2013-03-12 01:09:04
Used:
1,465,483 kbytes
Committed:
2,080,128 kbytes
Max:
2,080,128 kbytes
GC time:
2 minutes on ParNew (4,329 collections)
8.212 seconds on ConcurrentMarkSweep (72 collections)
big-GC 的总时间约为 8 秒,分布在 72 个独立的集合中。根据我的 JVM 提示,所有这些都低于 200 毫秒以限制暂停。
另一方面,我在我的独立网络日志 (wireshark) 中观察到一个 5 秒的网络响应时间实例。这意味着暂停存在,但它们不是 GC,也不是阻塞的线程或可以在探查器或线程转储中观察到的东西。
我的问题是调试或调整此行为的最佳方式是什么?
此外,我想了解 jHiccup 如何进行测量。显然不是GC停顿时间。
最佳答案
很高兴看到您正在使用 jHiccup,它似乎显示了基于现实的打嗝。
jHiccup 观察到 JVM 上运行的应用程序线程也会看到的“打嗝”。它不收集原因 - 只报告事实。原因可以是任何会导致进程无法完美运行准备运行代码的原因:GC 暂停是一个常见原因,但键盘上的临时 ^Z 或虚拟主机之间的“实时迁移”之一是也观察到了……有很多可能的原因,包括操作系统或管理程序级别(如果存在)的调度压力、电源管理疯狂、交换和许多其他原因。我已经看到 Linux 文件系统压力和 Transparent Huge Page“后台”碎片整理也会导致多秒的问题...
隔离暂停原因的第一步是在 jHiccup 中使用“-c”选项:它启动一个单独的控制进程(具有空闲的工作负载)。如果您的应用程序和控制进程都显示出在大小和时间上大致相关的打嗝,您就会知道您正在寻找系统级(而不是进程本地)原因。如果它们不相关,您就会怀疑 JVM 的内部——这很可能表明您的 JVM 因某些大事而暂停; GC 或其他东西,比如锁去偏或类加载派生去优化,如果安全点时间由于某种原因(并且在大多数 JVM,有许多可能导致安全点时间过长的原因)。
jHiccup 的测量非常简单,很难出错。整个东西不到650行java代码,大家可以自己看逻辑。 jHiccup 的 HiccupRecorder 线程重复 hibernate 1 毫秒,当它醒来时,它会记录任何大于 1 毫秒的时间差(与 hibernate 前相比)作为打嗝。简单的假设是,如果一个准备运行的线程(打嗝记录器)没有运行 5 秒,同一进程中的其他线程也会看到类似大小的打嗝。
正如您在上面提到的,jHiccups 观察结果似乎在您的独立网络日志中得到证实,您在其中看到了 5 秒的响应时间,请注意,网络日志不会观察到所有的打嗝,因为只有在网络记录器会观察到打嗝。相比之下,jHiccup 无法隐藏大于 ~1 毫秒的打嗝,因为即使没有其他 Activity ,它也会每秒尝试唤醒 1,000 次。
这可能不是 GC,但在您排除 GC 之前,我建议您多研究一下 GC 日志记录。首先,将暂停限制为 200 毫秒的 JVM 提示在所有已知的 JVM 上都是无用的。暂停提示相当于说“请”。此外,不要相信您的 GC 日志,除非您在选项中包含 -XX:+PrintGCApplicationStoppedTime(甚至怀疑它们)。有一些暂停和部分暂停可能会很长并且不会被报告,除非您包括此标志。例如。我已经看到偶尔长时间运行的计数循环导致暂停需要 15 秒才能到达安全点,其中 GC 仅报告它实际完成一些工作的暂停的 .08 秒部分。还有许多暂停的原因不被视为“GC”的一部分,因此可能不会被 GC 日志记录标志报告。
——吉尔。 [jHiccup 的作者]
关于java - jHiccup 分析没有加起来,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15350585/
这是一个复杂的查询,我希望用一条语句实现它,而不是必须在 PHP 中处理数组值。 要达到预期的输出: User Jobs Total John D. 5 $1245.67 Ma
SELECT B. * , SC.cate_name, ( CASE WHEN special_offer_type = 'Fixed Value' THEN B.price - special_o
关于将 booksleeve 与 protobuf-net 结合使用,我有一些相当基本的问题。现在我已经实现了一个单例类来管理连接,所以我多次重复使用与 recommended 相同的连接。 .现在我
我想要一个客户端加/减系统,用户可以单击加号,值会增加 1,减号,值会减少 1,该值永远不应该低于零,并且应该从 0 开始.有没有办法在 jquery 中简单地做到这一点?所有 jquery 插件都会
我正在使用加号和减号按钮更新我的产品数量,这很有效,但我的问题是因为我在一个容器中有多个产品,它正在更新所有产品的数量。这是代码:
我需要在大小相等的小整数数组上做大量简单的代数运算。这些操作仅包括三种:(i) 添加数组和 (ii) 按元素减去数组,以及 (iii) 比较一个数组中的所有元素是否不小于/大于另一个数组中的对应元素。
我对 javascript 很陌生,但我需要一种 JS 方式来在单击按钮时增加/减少输入字段中的值。我已成功将值设置为显示 0,但当我单击“添加”按钮时,它不会增加。 以下是 html 和 JS 代码
我可以在输入字段中添加/减去一个数字。 但是,我希望结果显示在中而不是在input中字段。 我尝试使用innerHTML自己完成它但无法让它发挥作用。 $(function() { $('.min
我的页面上有一个加号/减号 jquery 选择器。当页面加载或数字达到 1 时,我希望减号按钮变灰以模拟非事件状态。这是我的代码和 fiddle https://jsfiddle.net/pgxvhs
我如何加/减用户输入的十六进制数? 喜欢: basehex = input() sechex = input() sum = hex(basehex - sechex) print(sum) 我得到:
本文实例讲述了python简单实现矩阵的乘,加,转置和逆运算。分享给大家供大家参考,具体如下: 使用python完成矩阵的乘,加,转置和逆: ?
我输入的一些文本包括几个上下箭头(↑ 和 ↓),以及一个加号/减号 (±)。 这些特殊字符以 HTML ASCII 输入:↑ ↓ ±。在 POST 上,HTML 在保存到 MySQL 表之前使用 ht
我正在尝试配置 Live Gamer Portable 2 Plus 的输出引脚以降低帧速率。通过 GraphStudioNext,我可以通过捕获引脚访问配置并更改帧速率。 但是,当我通过 API 在
我正在尝试使用批处理文件创建任意时间。我试图从我的代码中减去设置值(例如1天,1个月和2000年),以显示系统时间减去前面所述的设置值。对于小时和分钟,我要减去10小时和10分钟(在代码中显示为不同的
我想建立一个 5 位向上/向下计数器。当我能让模拟工作时,我会更乐意购买零碎的东西来构建它。到目前为止,我使用的是 ATmega8,但坦率地说,只要组件相当便宜,任何解决方案都适合我。 我在网上找到了
使用 ng-repeat 时在数字输入字段上添加加/减切换的最佳方法是什么 我这样试过,但没用: - + vm.plus = f
我正在尝试弄清楚如何将 UNION 与相同的 JOIN 一起使用,而不是陷入 #2014 - 命令不同步。 我创建了四个简单的表格并为它们编写了简化的代码。主要想法是获得名字中带有“最佳”字样的每把剑
这个问题已经有答案了: Is floating point math broken? (33 个回答) 已关闭 9 年前。 我有一个简单的函数,应该生成 1000 个不同的元素: var start
我目前正在编写一个响应式设计,我正处于移动导航折叠的地步。 为此,我创建了两个 div 和一个 ul。 ul 包含我的 nav 元素,而 div 将显示移动设备和平板电脑下拉菜单的导航图像。 HTML
我为 woocommerce 单个产品页面创建了一个加/减数量按钮。创建了一个新的数量-input.php " min="" max="" name="" value="" ti
我是一名优秀的程序员,十分优秀!