У меня есть функция 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