Как проверить, запускал ли 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>
Ответы
Ответ 1
Вы определили StartCalendarInterval
, поэтому задание было выполнено, когда оно было загружено, и оно будет выполняться каждый день в 18:00.
Query launchd (8), чтобы узнать его статус выхода:
launchctl list | grep mytask
это вернет строку:
<pid> <status> mytask
Когда pid
- это число, работа выполняется в данный момент. В противном случае посмотрите status
, который является кодом выхода программы, node в вашем случае. Код выхода 0 означает либо то, что программа была успешно завершена, либо она еще не запущена. Положительные числа возвращаются для программных ошибок, а отрицательные - это то, что задание завершилось из-за сигнала.
Я предполагаю, что работа провалилась. Вы можете проверить стандартный вывод/ошибку программ. Задайте StandardOutPath
и StandardErrorPath
, чтобы сделать это. Содержимое этих файлов, скорее всего, скажет вам, почему программа не удалась.