私は新しいDebian安定システムをインストールして設定するために使用する一連のスクリプトを持っています。私が使用するプログラムを自動的に起動するには、/etc/rc.local
他の場合はファイルを手動で変更する必要があります/etc/inittab
。--noclear
行に追加するなどの他の変更があります1:2345:respawn:/sbin/getty --noclear 38400 tty1
。
終了プロセスをカスタマイズする必要があるため、最終的には次のようにしました。
l0:0:wait:/etc/rc.halt 0
...
l6:6:wait:/etc/rc.halt 6
これは私の/etc/rc.halt
姿です。
#!/bin/sh
#
# rc.halt
#
# This script is executed when entering level 6/0 (on halt or reboot)
su - teststand -c "/home/teststand/stop_server.sh" # my custom command
# making sure the halt/reboot process is resumed
test -n "${1}" && /etc/init.d/rc ${1}
exit 0
今日は、初めてデフォルトの初期systemd
化システムとして新しいDebian 8をインストールする日でした。こんなことは思わなかったけど、/etc/inittab
ファイルの損失があって初めて驚きました。
現在のシステム(@workと@home)はまだシステムを実行しているsysvinit
のでsystemd
。
以前のバージョンに変更できることはわかっていますが、で動作するものが何であるsysvinit
かを確認したいと思いますsystemd
。また、今すぐ新しいインストールをカスタマイズしていますが、完了する時間があまりないため、インストールは完了しません。今はドキュメントを見る時間がありません。
systemd
私の質問:動作をすばやく変更して追加し、--noclear
再起動/停止の開始点getty
として使用する方法はありますか?/etc/rc.halt
デフォルトでは、以前のinittab
変更をすばやくインポートできますかsystemd
?
ありがとう
答え1
systemdはSystem 5と互換性がなく、init
System 5のみ互換性がありますrc
。
Linux System 5スタイルのシステム管理は2つの部分で構成されています。init
これはプロセス#1として実行され、起動スクリプトrc
と停止スクリプトの実行を担当します。実際にはDebianの2つの異なるパッケージから来ました。 init
出身ですシステムベネットパッケージrc
一般的には以下で提供されます。sysv-rcパッケージですが、次から来ることもできます。ファイル-rcまたはオープンソースライブラリパック。
/etc/inittab
処理された設定ファイルですinit
。 systemd は、これに対する以前のバージョンとの互換性メカニズムを提供しません。 systemdのSystem 5以前のバージョンとの互換性メカニズムは、rc
実行中のSystem 5にのみ適用されます/etc/init.d/
。 (これはsystemdの特定のバージョンにのみ適用され、rc
systemdはfile-rcとopenrcの構成メカニズムの以前のバージョンとの互換性メカニズムを実装しません。)
これはsystemdに限定されていません。ほぼいいえinit / sysmanagerプロセスを交換します(30年に1回を除く)/etc/inittab
。
サービスをsystemdに接続するには、サービスが使用するメカニズムを使用する必要があります。するサポート、つまり自分のサービスユニットファイルと(自動的にユニットファイルに変換するジェネレータを介して).formatrc
システム5設定ファイル/etc/init.d/
。
ランレベルを忘れてください。
使用中のすべてのランレベルエントリは、システムLinuxオペレーティングシステムで「使用されていません」と宣言されています。 いいえランレベル0または6を入力できます。いくつかの互換性スペーサーがなければ存在しません。
サービスが終了したときにサービスを実行するには、サービスユニットを作成することが多くの人の当然の答えですWantedBy
。shutdown.target
しかし、ここにはいくつかの微妙な落とし穴があります。より良いがあまり明確ではない答えは、一般的なサービスユニットを作成し、終了ターゲットとDefaultDependencies=yes
競合していることを確認し、サービスのコアコンテンツExecStop
をExecStart
。
[単位] ドキュメント=https://unix.stackexchange.com/questions/233561/ [提供する] 種類=使い捨て ユーザー=テストベンチ 終了後の残り値=true ExecStart=/bin/true ExecStop=/home/teststand/stop_server.sh [インストールする] WantedBy =マルチユーザー。ターゲット
シェルスクリプトから貧しい人のデーモンマネージャを自分で作成しないでください。
これらの記事は常に正しく書かれていません。
「サービス」が単に「stop_server.sh」というコマンドを実行する場合、これは一部の手動シェルスクリプトサービス管理システムでサーバーを停止するスクリプトであると推測できます。
正しく作成されておらず、不安定で信頼できず、危険な災害についてのみ:stop_server.sh
stop_server.sh
stop_server.sh
stop_server.sh
stop_server.sh
stop_server.sh
あなたは体系化しました。 これを活用し、ここで実行されるすべてのサービスに適切なサービス管理メカニズムを使用します。ExecStop
必要に応じて、この奇妙なサービスはまったく必要ありません実際DefaultDependencies=true
サービスは、次のようにsystemdを介して実行できます。systemd がサービス終了を処理する終了時間中。
1つのサービスを「管理」するために、シェルスクリプトに貧しい人のデーモン監督者を雇い、それをシステムサービス単位でラップして2番目のサービスを提供し、終了時にそのサービスを開始する準備をするだけです。最初のサービス管理そして、システムが停止またはシャットダウンしたときにシステムをシャットダウンすることは、システム化された恐怖の家に入るための良い方法です。
世界はあなたが画面をきれいにしたいです。
〜したいいいえGreg Wooledgeと他の人が見つけたように、ログアウトとその後のログインの間に仮想端末を消去することは、実際に傾向に反することです。特権ユーザーまたは上司がログアウトした後も持続する機密出力は、1970年代からUnices(および実際には別の時分割リモートアクセスオペレーティングシステム)のセキュリティ上の問題であり、これらのすべての出力を取り消すにはかなりの努力が必要です。この問題を避けるために人々が置いたもの。
- 多くのシステムでは、
clear_console
シェルログアウトスクリプトに標準コマンドがあります。 (カーネル仮想端末#1で実行されるグラフィックプログラムではうまく動作せず、他の種類の端末(仮想または実際)では動作しないため、これ自体が問題になります。)このコマンドは削除する必要があります。
- たとえば、仮想端末を対象とするgettyプログラムのデフォルト設定は、端末を消去すること
mingetty
です。 (ログインする前にこれを行います。つまり、TTYログインサービスが停止してもターミナル出力が変わらない可能性があります。皮肉なことに、login
PAMの必要性のおかげでより良い場所に配置できますが、ログアウトしても実行されます中です。--noclear
この機能を無効にするには、このオプションを展開する必要があります。これには、ファイルを上書きしたり、設定を変更したりExecStart
、単に[email protected]
自分が設計したローカルユニットファイルを指す1つ以上のユニットファイルを作成することが含まれます。 - systemd が提供する
[email protected]
テンプレートサービスユニットセットは、TTYVTDisallocate=yes
systemd にカーネル仮想端末をクリアするよう指示します。 (これは名前が部分的に反映されるため、ユーザー空間の仮想端末を含む他の種類の端末では機能しません。)また、上書きまたは指定された他のサービステンプレートを使用して再度削除する必要があります
[email protected]
。
追加読書
- ジョナサンデボインポラード(2015)。
/etc/inittab
それは過去の仕事です。。一般的な答え。 - https://unix.stackexchange.com/a/196014/5132
- シャットダウンする前にsystemdを使用してスクリプトを実行する方法は?
- ジョナサンデボインポラード(2014)。
su
ユーザーの削除権限を乱用しないでください。。一般的な答え。 - グレッグ・ウリッジ(2014-04-08)。 私のクソコンソールのクリーニングはやめた。。グレッグのウィキ。
- ジョナサン・デ・ボイン・ポラード(2015-08-22)。Debian Jessie の複数の tty がシステムを停止します。。 [Eメール保護]。 Debian ユーザーです。
- https://unix.stackexchange.com/a/194218/5132
- ジョナサンデボインポラード(2015)。 システム化された恐怖の家。一般的な答え。
答え2
私はCentOS 7を使用していますが、設定が異なる場合があります。しかし、私にとっては、通話はgetty
サービスファイルによって制御されます。 (テンプレート用です。ファイルに渡される文字列で始まり、実行されるTTYを制御します。)このファイルには、コマンドラインを指定することから始まる行があります。ここにオプションが追加されます。 (下のファイルはシステムのアップグレードによって上書きされる可能性があるため、直接編集しないことをお勧めします。最初に下の場所にコピーする必要があります。これにより、ビジネス提供ファイルが非表示になる可能性があります。)/usr/lib/systemd/system/[email protected]
@
[email protected]
tty1
ExecStart=
/usr
/etc
/etc/systemd/system
systemd
シャットダウン/再起動を望む最善の方法は、シャットダウン/再起動プロセスを直接調整するのではなく、システムが停止または再起動したときに自動的に実行されるサービス終了タスクのリストにそのタスクを追加することです。 )を使用してサービスを手動で終了する場合systemctl
。これを行う簡単な方法は、スクリプトを1行のExecStop
システムサービスコマンドに置き換えることです。設定方法に応じて、全体を管理するユーザーサービスファイルを作成してそこExecStop
に配置することもできます。