gpt4 book ai didi

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

转载 作者:太空狗 更新时间:2023-10-29 11:18:29 27 4
gpt4 key购买 nike

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

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com