ฉันหาวิธีบันทึกกิจกรรม 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