web-dev-qa-db-ja.com

実行中のプロセスの実時間を取得するにはどうすればよいですか?

大きなファイルのハッシュチェックを開始しましたが、timeを使用して再起動したくありません。コマンドを呼び出す直前に時間を使用せずに、またはdateを使用せずに壁時計時間を取得するにはどうすればよいですか?

14
Dan S

実行中のプロセスの場合、これを行うことができます:

PID=5462
command ps -p "$PID" -o etime
command ps -p "$PID" --no-headers -o etime

一般的な機能として、シェルプロンプトを変更できます。これは私のbashプロンプトの定義です。

TERM_RED_START=$'\033[1m\033[31m'
TERM_RED_END=$'\033(B\033[m'
PS1='\nec:$(ec=$?; if [ 0 -eq $ec ];
then printf %-3d $ec;
else echo -n "$TERM_RED_START"; printf %-3d $ec; echo "$TERM_RED_END";
fi) \t  \u@\h:\w\nstart cmd:> '
PS2="cont. cmd:> "

あなたに関連する部分は\t時間。

ただし、これですべての問題が解決するわけではありません。プロセスが終了すると新しいプロンプトが表示されますが、測定対象のコマンドが開始されたとき、以前のプロンプトはかなり古い可能性があります。したがって、実行時間の長いコマンドを開始する前にプロンプ​​トを更新することを忘れないでください。または、現在のプロセスにかかった時間を知りたいときは、現在の時間を覚えておく必要があります。

完全なソリューションには、監査機能(プロセスの開始時間と終了時間を記録する)が必要です。ただし、シェルに制限できない場合、大量のデータが発生する可能性があります。

12
Hauke Laging

受け入れられた回答に基づいて、watchを使用して、実行中のプロセスの経過時間を継続的に監視することもできます。

PID=5462
watch command ps -p "$PID" -o etime
1
landroni