我对 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/