Debian を実行するサービスの開始に関する問題 [閉じる]

Debian を実行するサービスの開始に関する問題 [閉じる]

Debian ベースのデプロイ Raspian を使用して Raspberry Pi で UPNP レンダラーをサービスとして実行したいと思います。実際にすべてがうまく機能しますが、問題の1つは、起動時に適切な時間にサービスを開始できないことです。私にとっては、Wi-Fi接続が確立される前に早すぎます。したがって、レンダラーはネットワークに表示されません。手動でサービスを停止して再起動すると、正常に動作します。

ルートとして次のコマンドを実行してサービスを作成します。

update-rc.d gmediarender defaults

しかし、リンクはS02gmediarenderのように作成され、Wi-Fi管理者は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ディレクトリは次のとおりです。私はネットワーク管理者と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とネットワーク管理者が互いに干渉する可能性があると疑ったからです。そのため、それらのうちの2つを削除し、/etc/network/interfacesRPIがWiFiアクセスポイントにのみ接続するように設定しました。 KISS効果:シンプルで愚かなままにしてください。 ;-) Wi-Fi マネージャーのオーバーヘッドがなく、再起動後、GMediaRenderer がマイネットワークで動作するようになりました。

答え1

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

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

関連情報