Bash:在while循环中睡眠获得自己的pid

Use*_*er1 4 linux bash process-control

我有一个bash脚本,在循环中进行一些并行处理.我不希望并行进程加速CPU,所以我使用sleep命令.这是一个简化版本.

(while true;do sleep 99999;done)&

所以我从bash提示符执行上面的行,得到类似的东西: [1] 12345

[1]作业号在哪里,是12345while循环的进程ID(pid).我做了一个kill 12345得到:

[1]+  Terminated              ( while true; do
    sleep 99999;
done )

看起来整个脚本终止了.但是,我做了一个ps aux|grep sleep,发现睡眠命令仍然很强大,但有自己的pid!我可以杀了sleep,一切似乎都很好.但是,如果我先杀死睡眠,那么while循环会启动一个新的sleeppid.这对我来说是一个惊喜,因为睡眠与while循环并不平行.循环本身是一条执行路径.

所以我有两个问题:

  1. 为什么sleep命令获得自己的进程ID?
  2. 如何轻松杀死while循环和睡眠?

Mar*_*gen 5

  1. 睡眠PID是自己的,因为它是一个正在运行的过程,只是在等待.试着which sleep看看它在哪里.
  2. 您可以使用它ps -uf来查看系统上的进程树.从那里你可以确定PPID睡眠的shell(运行循环的那个)的(父PID)是什么.