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

标签 java linux io kernel

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

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

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

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

长话短说:如何测量我的每个方法调用的 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")));
}

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

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

关于java - 测量方法调用的 I/O 需求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30485295/

相关文章:

java - 如何将列表的内容附加到另一个列表的末尾?

java - 从 RecyclerView 的适配器设置 ImageView 颜色过滤器

java - Android 重用 Activity

linux - Debian 安装程序内核参数语法

java - 如何即时搜索/替换文件?

使用 inpout32.dll 的 Java I/O

haskell - I/O Monad 和 ByteString 到 Char 的转换?

java - ShakeService.java 通过 Intent 调用后不打印 Log 消息

Linux 内核在压力下有更好的响应时间

regex - 使用正则表达式通过 Bash 检查范围