1

Я пытаюсь запускать скрипт узла каждый час на моем 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

Почему не удается выполнить скрипт?

1 ответ1

1

Оказывается, я должен выполнить эту работу от имени пользователя root по любой причине.

Я переместил файл в /Library/LaunchAgents/agenttest.plist .

Я также обновил владение файлами с помощью sudo chown root /Library/LaunchAgents/agenttest.plist .

И файл разрешений с помощью sudo chmod 644 /Library/LaunchAgents/agenttest.plist .

Чтобы запустить задание от имени пользователя root: sudo launchctl load /Library/LaunchAgents/agenttest.plist

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .