Еще немного пищи для размышлений: используйте nmap или nc, никогда не пингуйте.
Пинг: Почему бы вам не использовать пинг? (1) Лучше проверять систему и порт одновременно. (2) Пинг ненадежен, так как эхо-сигнал icmp блокируется во многих ситуациях.
Nmap: Это очень быстро, очень надежно, но требует установки nmap
Предпочтительный метод NMAP (ex host ip 127.0.0.1):
nmap 127.0.0.1 -PN -p ssh | grep open
Nc: nc обычно уже установлен, однако в некоторых системах, таких как Mac OS X, команда зависает в недоступных системах. (см. Решение)
nc -v -z -w 3 127.0.0.1 22 &> /dev/null && echo "Online" || echo "Offline"
Временное решение для Mac OSX:
bash -c '(sleep 3; kill $$) & exec nc -z 127.0.0.1 22' &> /dev/null
echo $?
0
bash -c '(sleep 3; kill $$) & exec nc -z 1.2.3.4 22' &> /dev/null
echo $?
143
(примеры иллюстрируют подключение к порту 22 ssh через пример хорошего и плохого хоста, используйте $? Для определения, достиг ли он хоста со временем ожидания 3 секунды)
Для пользователей Mac (в основном) и т. Д. Вы можете использовать команду в сценарии следующим образом:
# -- use NMAP, if not avail. go with nc --
if command -v nmap | grep -iq nmap ; then
nmap ${ip} -PN -p ${ssh_port} | grep -iq "open"
res=$?
elif command -v nc | grep -iq nc ; then
# -- run command if fails to complete in 3 secs assume host unreachable --
( nc -z ${ip} ${ssh_port} ) & pid=$!
( sleep 3 && kill -HUP $pid ) 2>/dev/null & watcher=$!
if wait $pid 2>/dev/null; then
pkill -HUP -P $watcher
wait $watcher
# -- command finished (we have connection) --
res=0
else
# -- command failed (no connection) --
res=1
fi
else
echo "Error: You must have NC or NMAP installed"
fi
if [[ ${res} -lt 1 ]] ;then
success=1
echo "testing => $ip SUCCESS connection over port ${ssh_port}"
break;
else
echo "testing => $ip FAILED connection over port ${ssh_port}"
fi