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)

これは、ジョブが実行されたとき、ユーザーがcrontabを表示または編集したときなどを示します。これは、Snow Leopardマシンで見つけたものではありません。

回答:


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でテストおよび動作


うわー、はるかに簡単。賛成票を持っている。これがSnow Leopardで機能したのではないかと思います。
ダグ・ハリス

2
Mavericksで動作
Clustermagnet

1
ヨセミテの作品
nickcoxdotme

Snow Leopard、10.6.8で動作します(はい、私は骨m品です...)
ダニエルグリスコム

2
/System/Library/LaunchDaemons/com.apple.syslogd.plist:System Integrity Protectionが有効になっている間は操作が許可されません(10.13.2 High Sierra)。SIPを無効にする必要がありますか?ありがとう!
シェーンルー

12

各cronジョブアクティビティをlaunchdジョブに切り替えることなく、cronジョブアクティビティをログに記録する方法を考えました。

cronのmanページには言及して-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ジョブ・アクティビティのロギングを開始しました。また/var/log/cron.log、デフォルトの代わりに書き込むStandardErrorPathを追加しました/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は現在、cronではなくlaunchdを使用する傾向があります( Apple dev doc)。したがって、ログに記録するcronがない場合があります。

launchctlを使用して、launchdのロギングレベルを制御します。Somログ情報はsystem.logに表示されますが、コンソールアプリにはさらに表示されます->すべてのメッセージ


5
うーん、launchdへの切り替えは検討できるかもしれませんが、私は不機嫌な古いUNIXユーザーです。私はそのリンクをたどった。そのページの例は、24文字のcrontabを置き換える1046バイトの長さ0 0 7 11 0 happybirthdayです。
ダグ・ハリス

-1

少なくともYosemiteでは、cronは出力をmailメッセージとして記録するため、mailを使用してそれらを読み取ります。


cron(そうでない場合はリダイレクトされない)出力をメールでジョブの所有者に送信します。すべての出力がリダイレクトされる場合、メールは送信されません。(メッセージが送信されても​​、実行されたコマンドが表示されるかどうかはわかりません。)質問は、実行されたすべてのコマンドを管理者がどのように確認できるかを尋ねることcronです。あなたの答えを使うには、人は全員のメールファイルを見る必要があります。
G-Manは「
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.