Параллельная проверка процессов нескольких серверов с помощью оператора if

Параллельная проверка процессов нескольких серверов с помощью оператора if

У меня есть функция bash, которая проверяет, запущены ли какие-либо процессы на серверах, считывая их IP-адреса из текстового файла по одному.

  while read IP
  do
    if [ 1 -eq "$(echo "$(ssh -n ubuntu@$IP "top -b -n2 -d 0.5|grep Cpu|awk '{print \$2+\$4}'|tail -n1") > 1.0" | bc)" ];then
      echo "process is running on $IP"
    else
      echo "process is not running on $IP"
    fi 
  done < file.ips

file.ips содержит несколько IP-адресов сервера

202.X.X.X
203.X.X.X
204.X.X.X
...
...
...

Я хочу изменить эту функцию, чтобы проверить процесс, запущенный на нескольких серверах параллельно.

решение1

С помощью GNU Parallel вы можете:

check() {
  IP="$1"
  if [ 1 -eq "$(echo "$(ssh -n ubuntu@$IP "top -b -n2 -d 0.5|grep Cpu|awk '{print \$2+\$4}'|tail -n1") > 1.0" | bc)" ];then
    echo "process is running on $IP"
  else
    echo "process is not running on $IP"
  fi
}
export -f check
parallel -j0 check < file.ips

решение2


А как насчет запуска содержимого цикла в фоновом режиме?

  while read IP
  do
    (if [ 1 -eq "$(echo "$(ssh -n ubuntu@$IP "top -b -n2 -d 0.5|grep Cpu|awk '{print \$2+\$4}'|tail -n1") > 1.0" | bc)" ];then
      echo "process is running on $IP"
    else
      echo "process is not running on $IP"
    fi) & 
  done < file.ips

Связанный контент