测量 I/O 方法调用的需求

Measure I/O demands for method invocations

我对 Java EE 应用程序的性能测量(CPU 和磁盘 I/O 需求)感兴趣。

对于 CPU 我已经想出了如何衡量每个方法调用的 CPU 需求。通过在每个方法的开始和结束时调用 java.lang.management.ThreadMXBean.getCurrentThreadCpuTime()(例如使用 EJB 拦截器),我可以获得 CPU 处理此方法所需的 ("pure") 时间(CPU 需求)。

不幸的是,I/O 需求(磁盘:每个方法调用的读写时间)似乎很难衡量。 ThreadMXBean 不提供此类数据。由于暂停和同步时间的原因,仅从每种方法的完整响应时间中减去上述测量的 CPU 需求是不够的(如果可能的话,最好区分读和写)。

我正在考虑进一步深入到操作系统接口,以尝试调用系统调用或解析其他内核信息。目前,我正在尝试了解 "sar" 等工具如何测量 "iowait" 时间以及如何将此类数据映射到我的 Java 线程和各自的方法。但我不确定我是否正朝着正确的方向前进,因为我更深入的 OS 知识有限。

长话短说:如何衡量每个方法调用的I/O 需求(磁盘读写时间)?

提前致谢,bkk

好的,最近我开发了一个小型实用工具,用于测量我们其中一台服务器的一些性能指标。我使用 Java Mission Control (jmc) 记录指标并随后解析记录文件。在我的案例中,性能测试启动服务器并将基准测试工具附加到它(但您可以将其配置为附加到已启动的实例 - this link 提供了有关如何完成的更多信息)。我将在这里提供一些对您的用例代码行至关重要的代码。

1) 在启动服务器之前,我将以下 JMC 配置添加到命令行:

-XX:+UnlockCommercialFeatures
-XX:+FlightRecorder
-XX:StartFlightRecording=delay=5s,duration=120s,name=recording,filename=recording.jfr

所以在命令执行后,在 5 秒延迟后,它开始使用默认设置进行记录,并在 120 秒后生成报告文件。 2) 我正在使用以下方法检索 I/O 统计信息:

FlightRecording flightRecording = FlightRecordingLoader.loadFile(new File(...));
IView recording = flightRecording.createView();
for (IEvent event : recording) {
    FLRMethod method = (FLRMethod) event.getValue("((stackTrace).method)");
    /* this shows the bytes read by method at some invocation(if any), 
    so for total bytes read by method you will need to sum manually */
    long bytesRead = Long.valueOf(String.valueOf(event.getValue("bytesRead")));
}

您有很多东西需要探索,例如 read/write 文件花费的时间、读取次数等。您需要进行一些试验才能了解它的一些功能。 Java 的最新版本与 JMC 捆绑在一起。我只尝试过 Java 1.7 和 1.8

编辑:正如Klara指出的那样,您必须考虑阈值,这可以在您的设置文件中进行调整。因此,少于配置阈值的操作将不会添加到 JFR 记录中。