OS X上的cron操作日志


46

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)

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

Answers:


49

简单地将以下内容添加到/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


哇,简单得多。有一个upvote。我想知道这是否适用于Snow Leopard。
Doug Harris

2
适用于小牛队
Clustermagnet

1
作品在优胜美地
nickcoxdotme 2015年

在Snow Leopard上工作,10.6.8(是的,我是古董......)
Daniel Griscom 2016年

1
/System/Library/LaunchDaemons/com.apple.syslogd.plist:启用系统完整性保护时不允许操作(10.13.2 High Sierra)。我必须禁用SIP吗?谢谢!
Shane Lu

12

我想到了如何记录我的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 

1

OSX现在倾向于使用launchd而不是cron - Apple dev doc - 所以它可能在cron中没有任何内容可以记录。

使用launchctl来控制launchd的日志记录级别。Som日志信息出现在system.log中,但更多出现在控制台应用程序 - >所有消息中


5
嗯,切换到launchd是我可以考虑的事情,但我是一个脾气暴躁的老unix用户。我跟着那个链接。该页面上的示例长度为1046个字节,用于替换crontab的24个字符0 0 7 11 0 happybirthday
道格哈里斯2010年

-1

至少在Yosemite上,cron将输出记录为mail消息,因此使用它mail来读取它们。


cron通过邮件将(否则是未重定向的)输出发送给作业的所有者。如果重定向所有输出,则不发送邮件。(即使发送了一条消息,我也不确定它是否显示已执行的命令。)问题是询问管理员如何查看cron已执行的所有命令。要使用你的答案,一个人必须查看每个人的邮件文件。
G-Man
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.