1

今天,我 cron 并尝试检测核心转储并提醒我的东西实际上遇到了错误断言(当我在前台或后台的命令行上运行它时,通常核心会转储它)但没有核心被转储。我写了这个简单的测试:

int main
{
sleep(3);
assert(false);
}

当我编译和运行时,它会一直进行核心转储。但是当我把它放在 crontab 上时,我收到了一封来自 cron 守护进程的电子邮件,上面写着:

rocket: main.cpp:10: int main(int, char**): Assertion `false' failed.
/bin/sh: line 1: 32448 Aborted                 ./rocket

并且没有核心文件被放置在/cores. 为什么会这样,我怎样才能得到我的核心?

4

1 回答 1

6

要在崩溃时生成核心文件,必须在当前环境中启用核心转储。在 shell 中,这可以使用 ulimit 来完成:

ulimit -c unlimited

这意味着“将最大核心转储大小设置为无限制”。您的系统可能配置为在交互式 shell 中执行此操作,但不是在 cron 作业中。要从 cron 作业执行此操作,您需要修改此限制。如果 cron 作业是一个调用其他程序的 shell 脚本,你可以ulimit像上面那样调用。另一方面,如果作业是可执行文件,您可以创建一个包装器来运行它:

#!/bin/bash
ulimit -c unlimited
exec "$@"

另一种选择是修改程序以使用setrlimit函数设置限制本身。

至于为什么你的核心进入 /cores 而不是工作目录:你的发行版可能已经调整了核心模式,可能使用一个程序来处理核心文件并将它们放在 /cores 中。

于 2012-09-08T09:58:16.717 回答