如何在 Mac OS X Leopard 上的 dtrace 中使用热点探针?

Posted

技术标签:

【中文标题】如何在 Mac OS X Leopard 上的 dtrace 中使用热点探针?【英文标题】:How to use hotspot probes in dtrace on Mac OS X Leopard? 【发布时间】:2009-07-22 14:29:32 【问题描述】:

我的 Leopard 系统内置了 dtrace。我还使用 Apple 提供的安装程序安装了 Java 6:

$ java -version
java版本“1.6.0_13”
Java(TM) SE 运行时环境 (build 1.6.0_13-b03-211)
Java HotSpot(TM) 64 位服务器 VM(内部版本 11.3-b02-83,混合模式)

尽管如此,dtrace 在列出探针时没有显示热点探针:

$ sudo dtrace -l | grep 点
$

谁能告诉我如何在 Leopard 中为 Java 启用 dtrace 探测(假设它们随 Java 6 一起提供)?

【问题讨论】:

【参考方案1】:

“嗯,很有趣。我正在运行相同的配置,但对我来说,探针没有显示出来。你使用了什么命令行?还有“sudo dtrace -l | grep 点"?"

只有一个交叉检查。当您发出“sudo dtrace -l | grep spot”时,您应该有一个正在运行的 Java 应用程序。只有这样探针才会被列出。

【讨论】:

不,我没有运行 Java。确实它现在正在工作。谢谢! 探针命名为hotspot_jni5867,意味着进程ID包含在探针名称中。探针是在进程启动时动态创建的。【参考方案2】:

我正在使用 Java 1.6 运行 Snow Leopard,我可以看到热点探测器:

...

43223 hotspot_jni3644   libclient.dylib                   jni_AllocObject AllocObject-entry
43224 hotspot_jni3644   libclient.dylib                   jni_AllocObject AllocObject-return
43225 hotspot_jni3644   libclient.dylib           jni_AttachCurrentThread AttachCurrentThread-entry
43226 hotspot_jni3644   libclient.dylib           jni_AttachCurrentThread AttachCurrentThread-return
43227 hotspot_jni3644   libclient.dylib   jni_AttachCurrentThreadAsDaemon AttachCurrentThreadAsDaemon-entry
43228 hotspot_jni3644   libclient.dylib   jni_AttachCurrentThreadAsDaemon AttachCurrentThreadAsDaemon-return
43229 hotspot_jni3644   libclient.dylib             jni_CallBooleanMethod CallBooleanMethod-entry
43230 hotspot_jni3644   libclient.dylib             jni_CallBooleanMethod CallBooleanMethod-return

...

【讨论】:

嗯,很有趣。我正在运行相同的配置,但对我来说,探针没有出现。你用的是什么命令行?还有“sudo dtrace -l | grep spot”? 'sudo dtrace -l | grep 热点'就可以了。【参考方案3】:

您确定这也适用于 Apple JVM 吗?虽然有关 JDK 6 的文档中提到了 DTrace 挂钩,但您也可以在 Non-standard Java HotSpot VM Options 上找到(已添加重点):

-XX:-ExtendedDTraceProbes 启用影响性能的 dtrace 探针。 (在 6 中引入。仅与 Solaris 相关。

如果这是特定于平台的,则不是一个好兆头。 AFAIK Apple 构建了自己的定制 JVM。

【讨论】:

好点。看起来确实只有 Sun 的 JDK 支持 dtrace。 OpenJDK 已计划支持但似乎尚未实施。 Apple 的实施可能也是如此。

以上是关于如何在 Mac OS X Leopard 上的 dtrace 中使用热点探针?的主要内容,如果未能解决你的问题,请参考以下文章

Mac OS X Leopard 上的 Emacs 键绑定

Mac OS X Snow Leopard 上的 MOD_WSGI 困难

如何在Mac OS X 10.5 Leopard中刷新DNS

如何在 OS X Leopard 上的 bash 脚本中进行日期数学运算?

如何在 Mac OS X Snow Leopard 上启用 mysqli?

iPhone SDK 4 仅适用于 Mac OS X Snow Leopard?