web-dev-qa-db-ja.com

Debianを実行しているサービスの開始に関する問題

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がネットワークで利用できるようになりました。

4
Sun Wukong

最新のDebianは、依存関係ベースのinitシステムを使用しています。依存関係は、initスクリプトの上部にあるLSBヘッダーで定義されます。 $networkへの依存関係を定義する必要があります。

# Required-Start: $remote_fs $syslog $network
# Required-Stop: $remote_fs $syslog $network
3
jordanm