5

我有一台 2009 年中期的 MacBook Pro 和一台新的 2012 MacBook Pro,我正在学习 DTrace(一个非常棒的工具)。当我在新的 2012 MBP 上计算聚合时,聚合不会打印出来。

sudo dtrace -n 'syscall:::entry { @[execname] = count() }'

在我的 2009 年中期 MBP 中,它显示如下:

  usbmuxd                                                           1
  GrowlHelperApp                                                    2
  imklaunchagent                                                    2
  installd                                                          2
  stackshot                                                         2
  ...

2012 MBP 没有显示任何内容。

我在 BEING 和 END 探针中添加了一个 printf,以查看 END 探针是否会像这样触发:

BEGIN
{
    printf("Hi!");
}

syscall:::entry
{
   @[execname] = count();
}

END
{
    printf("Bye!")
}

在 2009 年中期的 MBP 上,两个探头都发射并打印了,而在 2012 MBP 上,只有 BEGIN 探头发射了。END 从未触发过。

两个 MBP 都运行 Lion 10.7.3。我不确定下一步该尝试什么。现在想到的唯一区别是我没有在 2012 MBP 上安装开发人员命令行工具。但这对我来说没有意义,而且是在黑暗中拍摄的。

任何帮助或想法将不胜感激。谢谢。

=============[已启用根帐户]====================

所以我启用了root帐户并重新运行了命令

sudo dtrace -n 'syscall:::entry { @[execname] = count() }'

没有成功,但如果我这样做

su
dtrace -n 'syscall:::entry { @[execname] = count() }'

有用!

=============[ kill -s INT ]=============================

我做了更多的实验。如果我运行:

sudo kill -s INT [pid of dtrace]

一切正常并显示输出。

如果我运行:

sudo kill -s INT [pid of sudo running dtrace]

这也有效!

但是如果我在终端中使用 control-c,它不会显示输出。

control-c 和 kill -s INT 有什么区别?

4

1 回答 1

5

我在linux上也注意到了。

如果 dtrace 由 sudo 生成,则 Ctrl-C 不起作用。

如果您 sudo -i 获得一个 root shell,然后调用 dtrace 它可以工作。

于 2012-07-10T03:58:07.493 回答