コマンドラインでコマンドを入力し、Enterキーを押しました。何も出力しません。実行中で、まだ出力されていないのか、ユーザーの入力を求めているのかを確認するにはどうすればよいですか?
cat
コマンドです。入力するだけでcat
、それ自体で、それが標準入力からの入力を待ちますが、何のプロンプトを与えません。他の多くのコマンドは、stdinまたはファイルからの入力を期待するため、同様に動作しますが、異なる入力ソース(対話式端末、パイプ、ファイル...)を区別しません。
コマンドラインでコマンドを入力し、Enterキーを押しました。何も出力しません。実行中で、まだ出力されていないのか、ユーザーの入力を求めているのかを確認するにはどうすればよいですか?
cat
コマンドです。入力するだけでcat
、それ自体で、それが標準入力からの入力を待ちますが、何のプロンプトを与えません。他の多くのコマンドは、stdinまたはファイルからの入力を期待するため、同様に動作しますが、異なる入力ソース(対話式端末、パイプ、ファイル...)を区別しません。
回答:
いくつかのアプローチがあります:
入力の終了を通知してみてください。スーパーユーザー特権がないと、ボンネットの下で何が起こっているのかを知るのは困難です。できることはCtrl+ を押すことdです。標準モードの端末とユーティリティはread()
、このキーの組み合わせにバインドされたEOT信号を受信すると、利用可能なすべてのテキストをsyscallに送信します。入力がない場合、read()
ほとんどのユーティリティは終了信号として受け入れる負の終了ステータスを返します。したがって、ユーティリティが入力を待機している場合、キーの組み合わせを受け取ると終了します。それ以外の場合、ユーティリティはタスクを実行しているか、正しく書き込まれていません。
syscallsのスパイ:スーパーユーザー特権を持っている場合はstrace
、別のターミナルで実行して、現在行われていることを確認できます。そのためには、プログラムのPIDを調べる必要があります。たとえば、別の端末タブで実行します。pgrep -f firefox
これは例として1234であり、その後になりsudo strace -f -p 1234
ます。表示される出力がread()
syscallでスタックしている場合、おそらくコマンドが入力を待っていることを意味します。それ以外の場合、syscallsが実行されているのを見ると、コマンドは別のことをしています。使用時間の関連する質問を参照strace
して、長時間実行されているコマンドが終了したかどうかを確認してください。
コマンド独自のメソッドを使用する:とりわけ、dd
信号を使用するなどのユーティリティ。たとえば、使用する場合kill -USR1 1234
(1234は実行中のdd
コマンドのPID )、現在処理されているバイト数を標準出力に出力します。もちろん、これには、そもそもコマンドのそのような動作について知る必要があります。上記の2つの方法はより一般的で、各コマンドの動作に関する深い知識は必要ありません(実際に実行していることを知ることが常に最善です-さもなければ、損害を与える可能性のあるコマンドを実行するリスクがあります)。
strace
メソッドに感謝します:-)しかし、より単純なメソッドも有用です(一般的または各プログラムに固有)。それらのいくつかは、スーパーユーザー特権なしで機能します。例:dd
何かをしているかどうかを確認し、なぜgrep --color asdf
静かに待機しているのかを確認します。
dd
それを追加することを思い出させてください。
それはプログラムとそれをどのように呼び出すかに依存します。
多くの場合、常にではありませんが、プロンプトが表示され、プログラムが入力を求めていることを示します。
わからない場合は、プログラムのプロセスがビジーかどうかを確認できます
CPUを使用- top
またはを使用htop
読み取りまたは書き込み-使用 sudo iotop -o
そして、プログラムが終了すると、シェルのプロンプトが表示されます。
running
プログラムが実行されているかどうかを確認するシェルスクリプトがあり、...が見つかったとき-s
に実行するオプションを追加しましたsudo strace -f -p <PID>
(Sergiy Kolodyazhnyyの回答による)。
シェルスクリプトは
ps -ef
大部分のプログラムを見つけるsystemctl is-active --quiet
いくつかのプログラムを見つけるあなたが希望する場合strace
にはxterm
、ウィンドウ。
プログラムのアクティビティを監視するxterm
ために使用strace
する場合にインストールします。
$ ./running
Usage: ./running <program-name>
./running <part of program name>
Examples: ./running firefox
./running term # part of program name
./running dbus
./running 'dbus-daemon --session' # words with quotes
./running -v term # verbose output
./running -s term # strace checks activity
簡単にアクセスしたい場合は、シェルスクリプトrunning
をディレクトリにインストールPATH
できます。
#!/bin/bash
# date sign comment
# 2019-02-14 sudodus version 1.0
verbose=false
strace=false
if [ "$1" == "-v" ]
then
verbose=true
shift
fi
if [ "$1" == "-s" ]
then
strace=true
shift
fi
if [ $# -ne 1 ]
then
echo "Usage: $0 <program-name>
$0 <part of program name>
Examples: $0 firefox
$0 term # part of program name
$0 dbus
$0 'dbus-daemon --session' # words with quotes
$0 -v term # verbose output
$0 -s term # strace checks activity"
exit
fi
inversvid="\0033[7m"
resetvid="\0033[0m"
redback="\0033[1;37;41m"
greenback="\0033[1;37;42m"
blueback="\0033[1;37;44m"
runn=false
#tmpfil=$(mktemp)
tmpdir=$(mktemp -d)
tmpfil="$tmpdir/tmpfil"
vtfile="$tmpdir/vtfile"
vthead="$tmpdir/vthead"
# check by systemctl
systemctl is-active --quiet "$1"
if [ $? -eq 0 ]
then
echo "systemctl is-active:"
runn=true
fi
# check by ps
ps -ef | tr -s ' ' ' ' | cut -d ' ' -f 8- | grep "$1" | grep -vE -e "$0 *$1" -e "$0 *.* *$1" -e "grep $1" | sort -u > "$tmpfil"
#cat "$tmpfil"
if $verbose || $strace
then
ps -ef |head -n1 > "$vthead"
ps -ef | grep "$1" | grep -vE -e "$0 *.* *$1" -e "grep $1" | sort -u > "$vtfile"
fi
tmpstr=$(head -n1 "$tmpfil")
#echo "tmpstr=$tmpstr"
tmpess=$(grep -om1 "$1" "$tmpfil")
#echo "tmpess=$tmpess"
if [ "$tmpstr" == "$1" ] || [ "${tmpstr##*/}" == "$1" ] || [ "${1##*/}" == "${0##*/}" ] || [ "$tmpess" == "$1" ]
then
echo "ps -ef: active:"
runn=true
if $verbose
then
cat "$vthead" "$vtfile"
fi
elif test -s "$tmpfil"
then
if $runn
then
echo "----- consider also ------------------------------------------------------------"
if $verbose
then
cat "$vthead" "$vtfile"
else
cat "$tmpfil"
fi
echo "--------------------------------------------------------------------------------"
else
echo "----- try with: ----------------------------------------------------------------"
if $verbose
then
cat "$vthead" "$vtfile"
else
cat "$tmpfil"
fi
echo "--------------------------------------------------------------------------------"
fi
fi
if $runn
then
echo -en "$greenback '$1"
if [ "$tmpstr" != "$tmpess" ]
then
echo -n " ..."
fi
echo -e "' is running $resetvid"
if $strace
then
which xterm
if [ $? -eq 0 ]
then
pid=$(head -n1 "$vtfile" | sed 's/^ *//' | tr -s ' ' '\t' | cut -f 2)
echo "checking pid=$pid; quit with 'ctrl + c' in the xterm window"
xterm -title "'strace' checks '$1'" 2> /dev/null -e sudo strace -f -p $pid
else
echo "Please install 'xterm' for this function to work"
exit
fi
fi
else
inpath=$(which "$1")
if [ "$inpath" == "" ]
then
echo -e "$redback no path found to '$1' $resetvid"
else
echo -e "$blueback '$1' is not running $resetvid"
fi
fi
rm -r "$tmpdir"
Lubuntuのターミナルウィンドウ(LXTerminalはx-terminal-emulator
カスタムgnome-terminal
ウィンドウとして起動)を確認します。
$ running -v -s term
----- try with: ----------------------------------------------------------------
UID PID PPID C STIME TTY TIME CMD
sudodus 2087 1384 0 13:33 ? 00:00:00 x-terminal-emulator
sudodus 2108 1269 0 13:33 ? 00:00:17 /usr/lib/gnome-terminal/gnome-terminal-server
--------------------------------------------------------------------------------
no path found to 'term'
$ running -v -s x-terminal-emulator
ps -ef: active:
UID PID PPID C STIME TTY TIME CMD
sudodus 2087 1384 0 13:33 ? 00:00:00 x-terminal-emulator
'x-terminal-emulator' is running
/usr/bin/xterm
checking pid=2087; quit with 'ctrl + c' in the xterm window
カーソルが端末ウィンドウにあるとすぐに多くのアクティビティがあります。
開始していますgrep
(からの入力を待っています/dev/stdin
)
$ grep -i --color 'hello'
asdf
Hello World
Hello World
確認する
$ running -s grep
ps -ef: active:
'grep ...' is running
/usr/bin/xterm
checking pid=14982; quit with 'ctrl + c' in the xterm window
あまり活動がなく、何が起きているかを特定できます。
iotop
プロセスがビジー状態の場合、CPUの使用率が必ずしも指標ではないかもしれませんけれども、。Cで記述され最適化されたプログラムは、最小限のCPUを使用している可能性があります。私がPythonで書いたインジケーターのいくつかは、繰り返しタスクを実行するようにスケジュールしているため、CPUを使用してインジケーターメニューを短時間更新し、そこに座っているだけかもしれません。
strace
この方法は、より良いですが、そうでないかもしれない必要または使用できません。
これがまだ必要かどうかはわかりませんが、知っておくと便利なトリックです:プログラムが出力なしで終了したように見える場合は、実行することでバックグラウンドで実行されているかどうかを確認できます
ps -efa | grep "program_name"
乾杯!
ターミナルエミュレーターや一般的なsshセッションなどのターミナルでシェルを実行している場合、シェルはほぼ確実にジョブ制御を有効にします。これにより、ほとんどの場合、質問への回答が非常に簡単になります。
入力Ctrl+Zしてプロセスを中断bg
し、バックグラウンドで続行し、シェルに空の行を入力して、プログラムがシグナルによって停止したかどうかを確認します。
プロセスが端末から読み込もうとしている場合、すぐにSIGTTIN
シグナルを受け取り、中断されます。(ジョブ制御が有効になっている場合、システムは端末からの読み取りを一度に1つのプロセスのみ許可します。)シェルはこれを報告します。次に、入力fg
してプロセスをフォアグラウンドで続行し、入力を入力して、通常どおりプログラムによって読み取られます。
mp@ubuntu:~$ sleep 30 # a program that is not reading from the terminal
^Z
[1]+ Stopped sleep 30
mp@ubuntu:~$ bg
[1]+ sleep 30 &
mp@ubuntu:~$
mp@ubuntu:~$
mp@ubuntu:~$ cat - # a program that is reading from the terminal
^Z
[1]+ Stopped cat -
mp@ubuntu:~$ bg
[1]+ cat - &
mp@ubuntu:~$
[1]+ Stopped cat -
mp@ubuntu:~$ jobs -l
[1]+ 3503 Stopped (tty input) cat -
mp@ubuntu:~$ fg
cat -
hi
hi
エディターなどの一部のプログラムはCtrl+Z、端末によって生成された信号をトラップまたは無視するか、制御文字が信号を生成しないモードに端末を設定します。あなたは、このような使用して、この場合は、より高度な技術、使用する必要がありますstrace
プロセスがやっているかどうかを確認するためにread
、select
、poll
、など
PS1
プロンプトは表示されません。