OS X 上的 cron 操作日志

Dou*_*ris 46 cron osx-snow-leopard macos

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)
Run Code Online (Sandbox Code Playgroud)

这会显示作业何时运行、用户何时查看或编辑 crontabs 等。我在我的 Snow Leopard 机器上找不到这些东西。

小智 52

简单地将以下内容添加到 /etc/syslog.conf 中要容易得多:

cron.*      /var/log/cron.log
Run Code Online (Sandbox Code Playgroud)

然后重启系统日志

sudo launchctl unload /System/Library/LaunchDaemons/com.apple.syslogd.plist
sudo launchctl load /System/Library/LaunchDaemons/com.apple.syslogd.plist
Run Code Online (Sandbox Code Playgroud)

在 OSX 10.7.4 上测试和工作

  • /System/Library/LaunchDaemons/com.apple.syslogd.plist:系统完整性保护启用时不允许操作(10.13.2 High Sierra)。我是否必须禁用 SIP?谢谢! (4认同)
  • 适用于小牛队 (2认同)

Dou*_*ris 13

我想出了如何记录我的 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)
Run Code Online (Sandbox Code Playgroud)

由于 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>
Run Code Online (Sandbox Code Playgroud)

-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 
Run Code Online (Sandbox Code Playgroud)