当少于 5 个终端打开时,IFS 循环继续

当少于 5 个终端打开时,IFS 循环继续

我有循环功能:

while IFS='|' read -r keyword; do
      xterm -e "echo -ne '\e[8;5;60t'; program -command"
done < ./filename

我只需要打开 5 个终端,program -command但是当一个终端完成工作并关闭时,循环应该再次开始打开,直到打开 5 个窗口。

我尝试

[ $( jobs | wc -l ) -ge 5 ] && wait

但在一项工作完成后,只有 4 个是打开的,并且要等到最后一项工作才打开并重新启动 5 次。

也许有些人可以修改这个脚本来工作

while [ `ps -p ${pid1},${pid2} | wc -l` < 5 ]
do
  sleep 1
done

该脚本每秒运行一次新终端......

while IFS='|' read -r keyword; do
      xterm -e "echo -ne '\e[8;5;60t'; program -command" &
      sleep 1
done < ./filename

但我需要一些东西来检查是否有打开的 5x 终端,如果没有,则再运行一次循环。

while IFS='|' read -r keyword; do
      xterm -e "echo -ne '\e[8;5;60t'; program -command"
      # Script to block loop until less than 5 terminal are open
      while [ `ps -p ${pid1},${pid2} | wc -l` < 5 ]
      do
        echo "There is less than 5 terminals opened"
      done
done < ./filename

我发现这样的东西,如何修改?

while [  $(ps -ef | grep KEYWORD | grep -v grep | wc -l) -gt 0 ]; do
sleep 1
done

我做了脚本

        child_count=$(($(pgrep --parent $$ | wc -l) - 1))
        if [ "$child_count" -lt "5" ]; then
            echo "Opened terminals: $child_count"
        else [ "$child_count" -ge "5" ]
            echo "Too many termianls: $child_count"; wait
        fi

但仍在等待所有完成,如果一个终端少于 5,则应每 10 秒检查一次

我找到了解决方案:

        check_processes(){
            while true; do
                child_count=$(($(pgrep --parent $$ | wc -l) - 1))
                if [ "$child_count" -lt "5" ]; then
                    echo "Opened terminals: $child_count"
                break
                else [ "$child_count" -ge "5" ]
                    echo "Too many termianls: $child_count"; sleep 10; check_processes
                fi
            done
            }
        check_processes

答案1

此代码段将创建五个xterm窗口。当你杀死它们时,另一只就会产生。

#!/bin/bash
#
pids=()

# Eternal loop
while :
do
    if [[ ${#pids[@]} -lt 5 ]]
    then
        # Start another process
        xterm &
        pid=$!

        # Save process id
        pids+=($pid)
    else
        # We have enough so wait for (at least) one to die
        wait -n

        # Reap old process ids
        oldpids=("${pids[@]}")
        pids=()
        n=0
        while [[ $n -lt ${#oldpids[@]} ]]
        do
            pid=${oldpids[$n]}
            [[ -n "$pid" ]] && kill -0 $pid 2>/dev/null && pids+=($pid)
            n=$((n+1))
        done
    fi
done

相关内容