Как проверить, запускал ли startd script? - программирование
Подтвердить что ты не робот

Как проверить, запускал ли startd script?

Я настроил launchd для запуска команды в 18 вечера каждый день на моем mac pro, но он не работал.

Я хочу проверить, запущена ли программа запуска. Я попробовал системную консоль, не нашел ничего ценного.

моя версия mac os - это mac os x 10.8.3

Мой файл plist:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>Label</key>
    <string>mytask</string>
    <key>Program</key>
    <string>/opt/local/bin/node</string>
    <key>ProgramArguments</key>
    <array>
        <string>/Users/xxx/My/task.js</string>
    </array>
    <key>StartCalendarInterval</key>
    <dict>
        <key>Hour</key>
        <integer>18</integer>
        <key>Minute</key>
        <integer>0</integer>
    </dict>
    <key>StandardOutPath</key>
    <string>/Users/xxx/launchd.stdout.log</string>
    <key>StandardErrorPath</key>
    <string>/Users/xxx/launchd.stderr.log</string>
</dict>
</plist>
4b9b3361

Ответ 1

Вы определили StartCalendarInterval, поэтому задание было выполнено, когда оно было загружено, и оно будет выполняться каждый день в 18:00.

Query launchd (8), чтобы узнать его статус выхода:

launchctl list | grep mytask

это вернет строку:

<pid> <status> mytask

Когда pid - это число, работа выполняется в данный момент. В противном случае посмотрите status, который является кодом выхода программы, node в вашем случае. Код выхода 0 означает либо то, что программа была успешно завершена, либо она еще не запущена. Положительные числа возвращаются для программных ошибок, а отрицательные - это то, что задание завершилось из-за сигнала.

Я предполагаю, что работа провалилась. Вы можете проверить стандартный вывод/ошибку программ. Задайте StandardOutPath и StandardErrorPath, чтобы сделать это. Содержимое этих файлов, скорее всего, скажет вам, почему программа не удалась.