DebianベースのディストリビューションであるRaspianを使用して、UPNPレンダラーをRaspberryPiでサービスとして実行したいと思います。実際には、すべてが正常に実行されますが、1つだけ、起動時に適切なタイミングでサービスを開始することができません。私には、wifi接続が確立される前に開始するのが早すぎるように見えます。その結果、レンダラーはネットワーク上で見ることができません。手動でサービスを停止して再起動すると、正常に機能します。
Rootとして、次のコマンドを実行してサービスを作成します。
update-rc.d gmediarender defaults
しかし、リンクはS02gmediarenderのように作成され、wifiマネージャーはS03wicdなので、gmediarenderの登録を解除した後、私は試しました:
update-rc.d gmediarender defaults 99
しかし、結果はまったく同じです。
もともと、私のスクリプトは:
#!/bin/sh
### BEGIN INIT INFO
# Provides: gmediarender
# Required-Start: $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start GMediaRender at boot time
# Description: Start GMediaRender at boot time.
### END INIT INFO
USER=root
HOME=/root
export USER HOME
case "$1" in
start)
echo "Starting GMediaRender"
start-stop-daemon -x /usr/local/bin/gmediarender -c pi:audio -S -- -f "Raspberry" -d
;;
stop)
echo "Stopping GMediaRender"
start-stop-daemon -x /usr/local/bin/gmediarender -K
;;
*)
echo "Usage: /etc/init.d/gmediarender {start|stop}"
exit 1
;;
esac
exit 0
ヘッダー部分を削除しようとしましたが、役に立ちませんでした。ご協力いただきありがとうございます :-)
$ network依存関係を追加した後、-nオプションを指定して(そして使用せずに)update-rc.dコマンドを発行しました。
pi@raspberrypi ~ $ Sudo update-rc.d -n gmediarender defaults 99
update-rc.d: using dependency based boot sequencing
insserv: enable service ../init.d/gmediarender -> /etc/init.d/../rc0.d/K01gmediarender
insserv: enable service ../init.d/gmediarender -> /etc/init.d/../rc1.d/K01gmediarender
insserv: enable service ../init.d/gmediarender -> /etc/init.d/../rc2.d/S02gmediarender
insserv: enable service ../init.d/gmediarender -> /etc/init.d/../rc3.d/S02gmediarender
insserv: enable service ../init.d/gmediarender -> /etc/init.d/../rc4.d/S02gmediarender
insserv: enable service ../init.d/gmediarender -> /etc/init.d/../rc5.d/S02gmediarender
insserv: enable service ../init.d/gmediarender -> /etc/init.d/../rc6.d/K01gmediarender
insserv: dryrun, not creating .depend.boot, .depend.start, and .depend.stop
pi@raspberrypi ~ $
これが私のrc2.dの説明です:network-managerとwicdが冗長ではなく、干渉して問題を引き起こす可能性があるのではないかと思いますか?
pi@raspberrypi /etc/rc2.d $ ll
total 4
lrwxrwxrwx 1 root root 17 oct. 28 23:43 K01lightdm -> ../init.d/lightdm
lrwxrwxrwx 1 root root 20 mars 16 19:20 K06nfs-common -> ../init.d/nfs-common
lrwxrwxrwx 1 root root 17 mars 16 19:20 K06rpcbind -> ../init.d/rpcbind
-rw-r--r-- 1 root root 677 févr. 8 01:26 README
lrwxrwxrwx 1 root root 18 oct. 28 22:56 S01bootlogs -> ../init.d/bootlogs
lrwxrwxrwx 1 root root 17 oct. 28 23:27 S01ifplugd -> ../init.d/ifplugd
lrwxrwxrwx 1 root root 14 oct. 28 22:56 S01motd -> ../init.d/motd
lrwxrwxrwx 1 root root 17 oct. 28 23:27 S01rsyslog -> ../init.d/rsyslog
lrwxrwxrwx 1 root root 14 mars 16 17:50 S01Sudo -> ../init.d/Sudo
lrwxrwxrwx 1 root root 22 oct. 28 23:27 S01triggerhappy -> ../init.d/triggerhappy
lrwxrwxrwx 1 root root 14 oct. 28 23:27 S02cron -> ../init.d/cron
lrwxrwxrwx 1 root root 14 oct. 28 23:27 S02dbus -> ../init.d/dbus
lrwxrwxrwx 1 root root 24 oct. 28 23:28 S02dphys-swapfile -> ../init.d/dphys-swapfile
lrwxrwxrwx 1 root root 22 mars 30 21:38 S02gmediarender -> ../init.d/gmediarender
lrwxrwxrwx 1 root root 13 oct. 28 23:27 S02ntp -> ../init.d/ntp
lrwxrwxrwx 1 root root 15 mars 16 18:00 S02rsync -> ../init.d/rsync
lrwxrwxrwx 1 root root 13 oct. 28 23:59 S02ssh -> ../init.d/ssh
lrwxrwxrwx 1 root root 22 mars 16 21:25 S03avahi-daemon -> ../init.d/avahi-daemon
lrwxrwxrwx 1 root root 19 mars 16 18:47 S03bluetooth -> ../init.d/bluetooth
lrwxrwxrwx 1 root root 25 mars 16 18:48 S03network-manager -> ../init.d/network-manager
lrwxrwxrwx 1 root root 14 mars 23 15:09 S03wicd -> ../init.d/wicd
lrwxrwxrwx 1 root root 20 mars 16 19:20 S04pulseaudio -> ../init.d/pulseaudio
lrwxrwxrwx 1 root root 18 mars 16 19:20 S05rc.local -> ../init.d/rc.local
lrwxrwxrwx 1 root root 19 mars 16 19:20 S05rmnologin -> ../init.d/rmnologin
pi@raspberrypi /etc/rc2.d $
新しい試み:/etc/rc2.d/S02gmediarender
の名前を/etc/rc2.d/S06gmediarender
に変更しようとしました。同じ問題:再起動後、サービスがネットワークに表示されません。
最後に:私は別の方向に進みました:wicdとnetwork-managerがおそらく互いに干渉しているのではないかと思ったので、問題をより単純にしました。そこで、2つを取り除き、/etc/network/interfaces
を構成して、RPIがwifiアクセスポイントに接続するようにしました。 KISS効果:シンプルでばかげた;-) Wi-Fiマネージャーのオーバーヘッドがなく、再起動後、GMediaRendererがネットワークで利用できるようになりました。
最新のDebianは、依存関係ベースのinitシステムを使用しています。依存関係は、initスクリプトの上部にあるLSBヘッダーで定義されます。 $network
への依存関係を定義する必要があります。
# Required-Start: $remote_fs $syslog $network
# Required-Stop: $remote_fs $syslog $network