Я пытаюсь запускать скрипт узла каждый час на моем Mac (OSX 10.8.2 Mountain Lion). Согласно высокопоставленным результатам поиска, лучший способ сделать это - добавить агент запуска launchd
.
По некоторым причинам это не похоже на работу.
Я написал следующий файл агента запуска и сохранил его как ~/Library/LaunchAgents/agenttest.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>KeepAlive</key>
<dict>
<key>SuccessfulExit</key>
<false/>
</dict>
<key>Label</key>
<string>protocol</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/bin/node</string>
<string>/Users/snorpey/PATH/TO/file.js</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>StartInterval</key>
<integer>3600</integer>
</dict>
</plist>
Я запустил агент запуска, запустив launchctl load ~/Library/LaunchAgents/agenttest.plist
в терминале.
Я также сделал исполняемый файл сценария с помощью sudo chmod -x /Users/snorpey/PATH/TO/file.js
и обновил права доступа к файлу с помощью sudo chmod 777 /Users/snorpey/PATH/TO/file.js
.
Когда я запускаю /usr/local/bin/node /Users/snorpey/PATH/TO/file.js
в терминале, скрипт работает нормально.
Тем не менее, он не работает, когда запускается launchd
. Я получаю следующие сообщения в /var/log/system.log
:
Jan 15 22:32:46 snorpey com.apple.launchd.peruser.501[595] (agenttest[21625]): Exited with code: 1
Jan 15 22:32:46 snorpey com.apple.launchd.peruser.501[595] (agenttest): Throttling respawn: Will start in 10 seconds
Почему не удается выполнить скрипт?