コマンドが実行されているのか、ユーザー入力を待っているのかを確認するにはどうすればよいですか?


14

コマンドラインでコマンドを入力し、Enterキーを押しました。何も出力しません。実行中で、まだ出力されていないのか、ユーザーの入力を求めているのかを確認するにはどうすればよいですか?


待機している場合、PS1プロンプトは表示されません。
Prvt_Yadav

1.どのプログラムであるか(サイレント)を教えてください。何を期待し、どのようにチェックするかについて、より正確なアドバイスを提供できます。2.プログラムが最終的に入力を要求するか終了したときにアラートを
受信し

予想される入力がある場合、入力を求めるメッセージの前にプロンプ​​トが表示されると想定します。
リンツウィンド

5
@Rinzwind-それは貧弱な仮定です。最初の反例は、catコマンドです。入力するだけでcat、それ自体で、それが標準入力からの入力を待ちますが、何のプロンプトを与えません。他の多くのコマンドは、stdinまたはファイルからの入力を期待するため、同様に動作しますが、異なる入力ソース(対話式端末、パイプ、ファイル...)を区別しません。
デイブシェロマン

回答:


15

いくつかのアプローチがあります:

  1. 入力の終了を通知してみてください。スーパーユーザー特権がないと、ボンネットの下で何が起こっているのかを知るのは困難です。できることはCtrl+ を押すことdです。標準モードの端末とユーティリティはread()、このキーの組み合わせにバインドされたEOT信号を受信すると、利用可能なすべてのテキストをsyscallに送信します。入力がない場合、read()ほとんどのユーティリティは終了信号として受け入れる負の終了ステータスを返します。したがって、ユーティリティが入力を待機している場合、キーの組み合わせを受け取ると終了します。それ以外の場合、ユーティリティはタスクを実行しているか、正しく書き込まれていません。

  2. syscallsのスパイ:スーパーユーザー特権を持っている場合はstrace、別のターミナルで実行して、現在行われていることを確認できます。そのためには、プログラムのPIDを調べる必要があります。たとえば、別の端末タブで実行します。pgrep -f firefoxこれは例として1234であり、その後になりsudo strace -f -p 1234ます。表示される出力がread()syscallでスタックしている場合、おそらくコマンドが入力を待っていることを意味します。それ以外の場合、syscallsが実行されているのを見ると、コマンドは別のことをしています。使用時間の関連する質問を参照straceして、長時間実行されているコマンドが終了したかどうかを確認してください。

  3. コマンド独自のメソッドを使用する:とりわけ、dd信号を使用するなどのユーティリティ。たとえば、使用する場合kill -USR1 1234(1234は実行中のddコマンドのPID )、現在処理されているバイト数を標準出力に出力します。もちろん、これには、そもそもコマンドのそのような動作について知る必要があります。上記の2つの方法はより一般的で、各コマンドの動作に関する深い知識は必要ありません(実際に実行していることを知ることが常に最善です-さもなければ、損害を与える可能性のあるコマンドを実行するリスクがあります)。


+1。straceメソッドに感謝します:-)しかし、より単純なメソッドも有用です(一般的または各プログラムに固有)。それらのいくつかは、スーパーユーザー特権なしで機能します。例:dd何かをしているかどうかを確認し、なぜgrep --color asdf静かに待機しているのかを確認します。
sudodus

@sudodusああ、ddそれを追加することを思い出させてください。
セルギーKolodyazhnyy

ユーザーが所有するプロセスをデバッグするためにスーパーユーザー権限は必要ありません。システムを適切にセットアップしていない場合を除きます。
ルスラン

6

プログラムが実行中か、ユーザー入力が必要かどうかを確認する方法

それはプログラムとそれをどのように呼び出すかに依存します。

  • 多くの場合、常にではありませんが、プロンプトが表示され、プログラムが入力を求めていることを示します。

  • わからない場合は、プログラムのプロセスがビジーかどうかを確認できます

    • 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を使用してインジケーターメニューを短時間更新し、そこに座っているだけかもしれません。
セルギーKolodyazhnyy

@SergiyKolodyazhnyy、はい、あなたはそれについて正しいです。straceこの方法は、より良いですが、そうでないかもしれない必要または使用できません。
sudodus

同意した。Ubuntuにプリインストールされているとは思いませんし、やり過ぎかもしれません。
セルギーKolodyazhnyy

1

これがまだ必要かどうかはわかりませんが、知っておくと便利なトリックです:プログラムが出力なしで終了したように見える場合は、実行することでバックグラウンドで実行されているかどうかを確認できます

ps -efa | grep "program_name"

乾杯!


1

ターミナルエミュレーターや一般的な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プロセスがやっているかどうかを確認するためにreadselectpoll、など

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.