Linux time コマンド:実行時間の計測

LinuxBeginner
オンラインで実践に進む

はじめに

この実験では、コマンドやプログラムの実行時間を測定するための強力なユーティリティである Linux の time コマンドについて学習します。あなたは TechInnovate 社のジュニアソフトウェア開発者として、一連のデータ処理スクリプトの最適化を担当することになりました。チームリーダーからは、パフォーマンスのボトルネックを特定するために time コマンドを使用するようアドバイスを受けています。この実践的な体験を通じて、time を活用してコードの効率を評価し、改善する方法を習得しましょう。

ファイル操作の計測

time コマンドは、コマンドの実行中に消費されたリソースに関する洞察を提供する多機能なツールです。まずは、簡単なファイル操作の時間を計測することから始めましょう。

最初に、内容を含むファイルを作成します。

echo "This is a test file for TechInnovate's performance analysis." > test_file.txt

このコマンドは、現在のディレクトリに test_file.txt という名前の新しいファイルを作成し、指定したテキストを書き込みます。> 記号は、echo の出力をファイルにリダイレクトするために使用されます。

次に、このファイルを読み取る操作の時間を計測してみましょう。

time cat test_file.txt

ファイルの内容が表示された後、実行時間の情報が表示されます。出力は以下のようになります。

This is a test file for TechInnovate's performance analysis.
cat test_file.txt  0.00s user 0.00s system 85% cpu 0.003 total

これらの計測値の意味は以下の通りです。

  • 0.00s user: プロセス内でユーザーモードのコード(カーネル外)の実行に費やされた CPU 時間。
  • 0.00s system: プロセス内でカーネル内での処理に費やされた CPU 時間。
  • 85% cpu: CPU 使用率の割合。
  • 0.003 total: エンターキーを押してからコマンドが終了するまでの経過時間(実時間)。

このような単純な操作では、これらの数値は非常に小さくなります。システムの負荷やその他の要因により、コマンドを実行するたびにわずかな変動が生じることがあります。

複雑なコマンドの計測

チームリーダーから、ログファイルを処理するスクリプトが提供されました。最適化の基準(ベースライン)を得るために、その実行時間を計測してみましょう。

まず、簡単な処理スクリプトを作成します。

cat << EOF > process_logs.sh
#!/bin/zsh
for i in {1..1000}; do
    echo "Processing log entry $i" >> output.log
done
sort output.log > sorted_output.log
uniq -c sorted_output.log > final_output.log
rm output.log sorted_output.log
EOF

chmod +x process_logs.sh

このスクリプトは以下の処理を行います。

  1. 1000 個のログエントリを生成するループを実行する。
  2. これらのエントリをソート(並べ替え)する。
  3. 重複を除いてエントリをカウントする。
  4. 中間ファイルを削除する。

chmod +x コマンドは、スクリプトを実行可能にします。

では、このスクリプトの実行時間を計測してみましょう。

time ./process_logs.sh

出力には、スクリプト全体の実行にかかった時間が表示されます。以下のようになります。

./process_logs.sh  0.03s user 0.01s system 92% cpu 0.045 total

これらの数値はシステムの性能によって異なりますが、最適化作業の基準値となります。合計時間(total)がユーザー時間(user)とシステム時間(system)の合計よりも長くなっていることに注目してください。この差は多くの場合、入出力(I/O)操作(この場合はファイルの読み書き)に起因します。

さまざまなコマンドでの time の使用

time コマンドが異なる種類の操作に対してどのように反応するかを調べてみましょう。これにより、さまざまなタスクの結果をどのように解釈すべきか、より深く理解できるようになります。

まず、CPU 負荷の高い操作を計測します。

time echo {1..10000} | wc -w

このコマンドは一連の数値を生成し、その単語数をカウントします。主に CPU に負荷がかかる処理です。

次に、I/O(入出力)負荷の高い操作を計測します。

time find / -name "*.txt" 2> /dev/null

このコマンドは、ルートディレクトリからすべての .txt ファイルを検索します。主にディスク I/O に負荷がかかる処理です。

最後に、CPU と I/O の両方を使用するコマンドを計測します。

time sort -R /etc/passwd | head -n 5

このコマンドは /etc/passwd ファイルの内容をランダムにソートし、最初の 5 行を表示します。

これらのコマンドの出力を比較してみてください。CPU 負荷の高いタスクはユーザー時間が長くなる傾向があり、I/O 負荷の高いタスクはユーザー時間やシステム時間に比べて合計時間(total)が長くなることが多いことに気づくはずです。

まとめ

この実験では、コマンド実行の計測と最適化に不可欠なツールである Linux の time コマンドについて学習しました。以下の方法を習得しました。

  1. ファイル操作の時間を計測してパフォーマンスを評価する。
  2. 複雑なスクリプトの実行時間を測定する。
  3. CPU 負荷、I/O 負荷、および混合型の操作における time の挙動を比較する。

これらのスキルは、TechInnovate 社での業務においてスクリプトの最適化やパフォーマンス分析を継続する上で非常に役立ちます。

コードを最適化する際のポイントを忘れないでください。

  • 実行時間が予想外に長い操作を探す。
  • CPU 時間(user + system)と合計時間(total)の両方を考慮する。
  • I/O 負荷の高い操作では、合計時間と CPU 時間の差を縮めることに注力する。
  • CPU 負荷の高い操作では、ユーザー時間を短縮することに注力する。

これらのテクニックを実務に適用することで、コード内のパフォーマンスのボトルネックを特定し、解決する能力がさらに向上するでしょう。