
シェルスクリプトの終了コードを理解する
終了コード(一般的にリターンコードまたは終了ステータスと呼ばれる)は、プログラム、スクリプト、またはコマンドの実行完了時にオペレーティングシステムに送信される数値信号です。これらのコードは、長いログを精査することなく貴重な情報を提供し、障害や問題を迅速に診断するのに役立ちます。
シェル スクリプトの領域では、プロトコルは単純です。正常に実行された場合は の終了コードが返されます0
が、ゼロ以外の値は通常はエラーを意味し、標準値は から の間に存在し1
ます255
。
Unix系環境(BashやZshなど)で最後に実行されたコマンドの終了コードを確認するには、特殊変数 を利用します$?
。手順は以下のとおりです。
ls /nonexistent_directoryecho $?

このコマンドはecho $?
、最後のコマンドの終了コードを表示します。 の結果は成功を示し、 、、 など0
の値は、ファイルの不足や権限の問題など、さまざまなエラーを示します。1
2
127
スクリプトのデバッグに終了コードを活用する
終了コードを使用すると、スクリプトのデバッグ能力が大幅に向上します。終了コードを使用すると、スクリプトは操作が成功したか失敗したかを識別し、それに応じて後続のステップを決定できます。
次の実際的な例を考えてみましょう。スクリプトは、ファイルをバックアップの場所にコピーし、その成功を報告するように設計されています。
#!/bin/bash # Attempt to copy the file cp important_file.txt backup/# Verify if the copy was successful if [ $? -eq 0 ]; then echo "Backup successful!" else echo "Backup failed with exit code $?" exit 1 # Send an error code, indicating failure fi
cp
ここで、コマンドが終了コード を返した場合0
、すべて正常に実行されていることを示します。0以外の値を返すと、スクリプトはエラーメッセージを出力し、終了コード で終了します1
。
カスタム終了コードの作成
既存の終了コードをチェックするだけでなく、様々なエラーを示すカスタムコードを定義することもできます。これによりスクリプトの明確さが向上し、ユーザーが発生する可能性のある具体的な問題を特定しやすくなります。
例として、次のスクリプトを考えてみましょう。
#!/bin/bash # Ensure an argument (filename) is provided. if [ -z "$1" ]; then echo "Usage: $0 <filename>" exit 1 # Exit code 1 indicates missing argument fi # Check for the existence of the file provided if [ ! -f "$1" ]; then echo "Error: File not found" exit 2 # Custom exit code 2 indicates file absence fi
この構造により、ユーザーはエラーを素早く把握できます。終了コードは1
引数が与えられなかったことを意味し、は2
ファイルが存在しないことを示します。このような明確な構造は、スクリプトが大規模システムのコンポーネントである場合に特に役立ちます。
一般的な終了コードのガイド
終了コードはプログラムによって異なりますが、特にLinuxやUnix系システムでは、一般的なパターンがあります。以下に、よく見られる終了コードをまとめます。
-
0
: 成功 – 操作は問題なく完了しました。 -
1
: 具体的な詳細のない一般的なエラーが発生しました。 -
2
: シェル組み込みコマンドの誤用。多くの場合、パラメータの欠落が原因です。 -
126
: コマンドは見つかりましたが、実行権限がありません。 -
127
: コマンドが見つかりません。存在しないか、スペルが間違っています。 -
128
: 終了コードのセマンティクスと矛盾する無効な終了引数です。 -
130
: プログラムはCtrl+によって停止しましたC。 -
137
: メモリ不足のためプロセスが終了しました。 -
255
: 有効範囲を超える終了コードを返そうとしました。
アプリケーションによっては、独自の終了コードを割り当てる場合があります。例えば、grep
コマンドは0
一致した場合、1
一致しない場合、2
エラーが発生した場合などに返します。開発者は通常、Unix系環境では0
から までのすべての値を使用します。255
終了コードを利用したコマンドの連鎖
Bash スクリプトには と の 2 つの演算子があり、これらを使用する&&
と、先行するコマンドの||
成功 (終了コード0
) または失敗 (ゼロ以外の終了) に基づいてコマンドをリンクできます。
-
&&
: 前のコマンドが成功した場合にのみ、次のコマンドを実行します。 -
||
: 前のコマンドが失敗した場合は、次のコマンドを実行します。
例えば、ディレクトリを作成し、その後そのディレクトリに切り替えるといったシナリオが考えられます。どちらの操作も失敗した場合、問題を示すエラーメッセージが表示されます。
mkdir new_directory && cd new_directory || echo "Failed to create and access directory"
この場合、コマンドはmkdir new_directory
ディレクトリの確立を試みます。成功した場合は、直ちに に進みますcd new_directory
。これらのいずれかが失敗した場合は、||
オペレータが起動し、エラーメッセージが表示されます。
最後に
些細なことのように見えるかもしれませんが、終了コードはコマンドライン機能の重要な側面を構成しています。プログラムが成功と失敗を伝えるための標準化された方法を確立し、複雑なシステムを調整するための不可欠な要素となります。
コマンドラインインターフェースの世界に足を踏み入れるなら、echo $?
コマンドが期待通りの結果にならない場合は必ず確認するようにしましょう。そうすれば、すぐにスクリプト作成において終了コードの使い方を習得し、コマンド間の通信を強化する上での終了コードの重要な役割を理解できるようになるでしょう。
よくある質問
1.シェル スクリプトにおける終了コードはどのような意味を持ちますか?
終了コードは、シェルスクリプトにおいて、コマンドまたはスクリプトの成功または失敗を示す数値信号として機能します。0 は0
成功を示し、0以外の値は様々なエラーを示します。
2. Bash でコマンドの終了コードを確認するにはどうすればよいですか?
最後に実行したコマンドの終了コードを確認するには、 コマンドを使用しますecho $?
。これにより、診断用の数値の終了コードが表示されます。
3.スクリプト内で独自の終了コードを設定できますか?
もちろんです!スクリプト内でカスタム終了コードを定義して、特定のエラー状態を伝えることができます。これにより、スクリプトの情報量が増え、ユーザーフレンドリーになります。
コメントを残す ▼