「サービス{FOO}が開始しました」と「/etc/init.d/{FOO}が起動しました」? [閉鎖]

「サービス{FOO}が開始しました」と「/etc/init.d/{FOO}が起動しました」? [閉鎖]

Debian 8 デスクトップで CrashPlan を使用しています。 CrashPlanサービスを最初に停止し、終了する前に開始する必要があるスクリプトがあります。使っています

/etc/init.d/crashplan start

再起動しますが、終了すると新しいCrashPlanプロセスが終了します。私のものスクリプト。私は次に切り替えます

service crashplan start

すべて大丈夫!

奇妙なことに、Ubuntu 16.04の他のシステムでは、init.dスクリプト/コマンドが期待どおりに機能します。私のスクリプトが終了すると、CrashPlanは引き続き実行されます。 さて、今Ubuntuは私に同じ問題を抱えています。

私のDebianスクリプトは今動作します。しかし、私はこのコマンドがまもなく使用されなくなるという印象を受けています。したがって、現在のバージョンのDebianとUbuntuの違いについてserviceは混乱しています。init.dservice

ベストアンサー1

systemdを使用するすべてのシステムでinit.dスクリプトを直接実行することは、サービスを開始する最善の方法ではありません。これは通常、systemd自体が実行するすべての設定とブックをバイパスするためです。さらに、初期化スクリプトがない可能性があり、サービスが単体ファイルにのみ記述される可能性があります。

「古い」sysvinitでは、本を書く必要はあまりありません。サービスの起動は、スクリプトの実行とほぼ同じです。これは、initスクリプトを直接使用するのが良いアイデアではなく、マニュアルページの説明からserviceその理由がわかります。

service可能な限り予測可能な環境で System V init スクリプトまたは開始ジョブを実行し、ほとんどの環境変数を削除し、現在の作業ディレクトリを / に設定します。

ランダムシェルは予測可能な環境ではなく、ファイルまたはプロセスの制限を有効にできます。

サポートの中断については使用する必要があるかもしれませんが、systemctlDebianではservice実際に正しいことを試してsystemctl実行します。 (ifがserviceもう使用されていないと仮定すると、initスクリプトを直接実行する方がはるかに優れています。)

(私はinitスクリプトを直接実行している場合、サービスが何を終了するのかを正確に知らせるほどシステムの専門家ではありません。また、実行中のスクリプトを実行するターゲットによって異なります。

おすすめ記事