Linuxサービスvlcpulseアクセスが拒否されました。

Linuxサービスvlcpulseアクセスが拒否されました。

オーディオを再生するRaspberry 3のRaspbian OS 11 liteで実行されるサービスがあります。

[Unit]
Description=My script to monitor the shutdown button
After=multi-user.target

[Service]
ExecStart=/usr/bin/python /home/pi/Radio/Radio/main.py
User=root
Group=root

[Install]
WantedBy=multi-user.target

サービスが実行されており、ユーザーの入力を読み取り、ユーザーと対話します。ただし、音楽を再生しようとすると、常に次のエラーが発生します。

Oct 10 18:22:57 raspberrypiradio python[4180]: [755aa250] main audio output error: Audio output failed
Oct 10 18:22:57 raspberrypiradio python[4180]: [755aa250] main audio output error: The audio device "default" could not be used:
Oct 10 18:22:57 raspberrypiradio python[4180]: Connection refused.
Oct 10 18:22:57 raspberrypiradio python[4180]: [755aa250] main audio output error: module not functional
Oct 10 18:22:57 raspberrypiradio python[4180]: [7312c1f0] main decoder error: failed to create audio output
Oct 10 18:24:00 raspberrypiradio python[4180]: [75591ca8] vlcpulse audio output error: PulseAudio server connection failure: Access denied
Oct 10 18:24:01 raspberrypiradio python[4180]: [75588cb0] vlcpulse audio output error: PulseAudio server connection failure: Access denied
Oct 10 18:24:01 raspberrypiradio python[4180]: [73d01830] http stream error: cannot resolve stream.rockantenne.de: System error
Oct 10 18:24:01 raspberrypiradio python[4180]: [73d01830] access stream error: HTTP connection failure
Oct 10 18:24:01 raspberrypiradio python[4180]: [73d01830] http stream error: cannot connect to stream.rockantenne.de:80

端末を介して直接ファイルを再生すると、main.pyすべてがうまく動作します。 Pythonファイルでサウンドを再生しています仮想LC

私は常にサービスをmain.py実行したいので、サービスを使用しています。特に、システムを再起動した後はさらにそうです。

ベストアンサー1

サービスタグの下のサービスファイルに追加してみてください。

Environment=XDG_RUNTIME_DIR=/run/user/1000

もちろん、現在のユーザーに合わせてディレクトリを変更する必要があります。あなたは実行することができます

printenv | grep -i 'xdg_runtime_dir'

サービスファイルにコピーする内容を決定します。

これにより、vlcpulseサーバーへの接続拒否の問題が解決されますが、DNSエラーが発生してリモートストリームを確認できないようです。これは、解決するためにより多くの情報が必要な別の問題です。

おすすめ記事