Журнал действий cron в OS X

cron, который поставляется с OS X, регистрирует свои действия где угодно?

Я не ищу вывод какой-либо конкретной работы 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)

Это показывает, когда задания выполняются, когда пользователям просматривать или редактировать файлами и т. д. Эта штука нигде не встречается на моей машине снежного барса.

25
задан Doug Harris
28.11.2022 22:52 Количество просмотров материала 2370
Распечатать страницу

4 ответа

гораздо проще просто добавить следующее в /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

48
отвечен phil 2022-11-30 06:40

Я понял, как регистрировать активность работы cron без переключения каждого из них на задания запуска.

cron man page упоминает -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 
12
отвечен Doug Harris 2022-11-30 08:57

OSX теперь использует launchd, а не cron - Apple dev doc - Так что, возможно, в cron нет ничего для входа.

используйте launchctl для управления уровнем ведения журнала launchd. Информация журнала Som отображается в системе.войти, но больше в консольном приложении - > все сообщения

1
отвечен Mark 2022-11-30 11:14

по крайней мере, на Yosemite, cron регистрирует вывод как mail сообщений, так что используйте mail читать их.

-1
отвечен mcandre 2022-11-30 13:31

Постоянная ссылка на данную страницу: [ Скопировать ссылку | Сгенерировать QR-код ]

Ваш ответ

Опубликуйте как Гость или авторизуйтесь

Имя
Вверх