OS X 自带的 cron 是否在任何地方记录其操作?
我并不是在寻找任何特定 cron 作业的输出,而是 cron 正在执行的操作的日志。在我检查过的几台 Linux 机器上,有/var/log/cron
以下内容:
Apr 26 11:00:01 localhost crond[27755]: (root) CMD (/root/bin/mysql-backup)
Apr 26 11:01:01 localhost crond[27892]: (root) CMD (run-parts /etc/cron.hourly)
Apr 26 11:07:01 localhost crond[28138]: (root) CMD (/usr/local/bin/python /home/
user1/scripts/pythonscript.py)
Apr 26 11:18:18 localhost crontab[28921]: (user2) LIST (user2)
Apr 26 11:18:22 localhost crontab[28929]: (user2) BEGIN EDIT (user2)
Apr 26 11:18:59 localhost crontab[28929]: (user2) REPLACE (user2)
这显示了作业运行的时间、用户查看或编辑 crontab 的时间等。我在我的 Snow Leopard 机器上找不到这些东西。
答案1
只需将以下内容添加到 /etc/syslog.conf 就更容易了:
cron.* /var/log/cron.log
然后重新启动 syslog
sudo launchctl unload /System/Library/LaunchDaemons/com.apple.syslogd.plist
sudo launchctl load /System/Library/LaunchDaemons/com.apple.syslogd.plist
已在 OSX 10.7.4 上测试并运行
答案2
我知道如何记录我的 cron 作业活动,而无需将每个作业切换到启动的作业。
这cron 手册页提到了启用-x
“将调试信息写入标准输出”的选项。这样做的副作用是,这些选项还会将基本信息写入标准错误。发送到标准错误的数据将写入/var/log/system.log
。
这会导致如下数据被写入/var/log/system.log
:
debug flags enabled: misc
[42073] cron started
log_it: (user1 42084) CMD (/root/bin/mysql-backup)
log_it: (user1 42094) CMD (run-parts /etc/cron.hourly)
由于 cron 本身是由 launchd 启动的,为了启用此功能,我必须进行编辑,/System/Library/LaunchDaemons/com.vix.cron.plist
使其现在看起来像这样:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN"
"http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>com.vix.cron</string>
<key>ProgramArguments</key>
<array>
<string>/usr/sbin/cron</string>
<string>-x</string>
<string>misc</string>
</array>
<key>KeepAlive</key>
<dict>
<key>PathState</key>
<dict>
<key>/etc/crontab</key>
<true/>
</dict>
</dict>
<key>QueueDirectories</key>
<array>
<string>/usr/lib/cron/tabs</string>
</array>
<key>EnableTransactions</key>
<true/>
<key>StandardErrorPath</key>
<string>/var/log/cron.log</string>
</dict>
</plist>
我-x misc
在这里使用了,但似乎使用哪个选项并不重要。添加-x
开始记录作业活动。我还添加了要写入的 StandardErrorPath,/var/log/cron.log
而不是默认的/var/log/system.log
。
然后卸载并重新加载:
$ sudo launchctl
Password:
launchd% unload /System/Library/LaunchDaemons/com.vix.cron.plist
launchd% load /System/Library/LaunchDaemons/com.vix.cron.plist
答案3
OSX 现在倾向于使用 launchd 而不是 cron - Apple 开发文档- 因此 cron 中可能没有任何内容可以记录。
使用 launchctl 控制 launchd 的日志记录级别。一些日志信息出现在 system.log 中,但更多出现在控制台应用程序中 -> 所有消息
答案4
至少在 Yosemite 上,cron 将日志输出为mail
消息,因此请使用来mail
读取它们。