Luanchd не запускает mopidy & UDP listener - PullRequest
0 голосов
/ 28 мая 2019

Я пытаюсь написать скрипт Launchd для выполнения простого скрипта sh, который будет 1) запускать mopidy 2) mkfifo /tmp/mopidy.fifo 3) передавать данные из порта 5555 в этот файл с помощью socat.

Я попытался настроить LaunchAgent mopidy.plist, который выполняет файл сценария mopidy.sh при входе в систему.Я проверил, что LaunchAgent запускается правильно и что скрипт имеет разрешения на выполнение.Я также попробовал подход «Программные аргументы», передав скрипт в виде однострочного в / bin / bash, но когда я пытаюсь это сделать, я получаю сообщения об ошибках, в которых говорится, что он не может найти socat.

mopidy.sh

nohup mopidy;
mkfifo /tmp/mopidy.fifo;
while :; do 
    socat -d -d -T 1 -u UDP4-LISTEN:5555 OPEN:/tmp/mopidy.fifo; 
done

mopidy.plist

<!-- Starts mopidy server -->
<?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>com.me.mopidy.plist</string>
    <key>Program</key>
      <string>/Users/me/.config/scripts/mopidy.sh</string>
    <key>RunAtLoad</key>
    <true/>
    <key>KeepAlive</key>
    <true/>
    <key>StandardOutPath</key>
    <string>/Users/me/logfile.log</string>
    <key>StandardErrorPath</key>
    <string>/Users/me/error_logfile.log</string>
</dict>
</plist>

Я могу нормально выполнить скрипт bash без ошибок из командной строки, однако это не такПохоже, что сервис способен, потому что файл /tmp/modipy.fifo никогда не создается, а слушатель никогда не создается.Лог-файл и error_logfile также никогда не заполняются.

1 Ответ

0 голосов
/ 28 мая 2019

Мне удалось заставить его работать, включая переменные окружения.Я не совсем понимаю это, но теперь все работает со следующим:

<!-- Starts mopidy server -->
<?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>com.me.mopidy.plist</string>
    <key>EnvironmentVariables</key>
    <dict>
        <key>PATH</key>
        <string>/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/sbin</string>
    </dict>
    <key>ProgramArguments</key>
    <array>
        <string>/bin/bash</string>
        <string>/Users/me/.config/scripts/mopidy.sh</string>
    </array>
    <key>RunAtLoad</key>
    <true/>
    <key>KeepAlive</key>
    <true/>
    <key>StandardOutPath</key>
    <string>/Users/me/logfile.log</string>
    <key>StandardErrorPath</key>
    <string>/Users/me/error_logfile.log</string>
</dict>
</plist>
...