我有一台 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 有什么区别?