外壳脚本 - 当 ping 失败时循环停止



我正在尝试编写一个 shell 脚本来 ping 指定文件中列出的每个服务器并获得其正常运行时间。预期的行为是,如果在 ${TIMEOUT} 秒后未到达服务器,脚本将停止尝试 ping 该服务器,并继续移动到列表中的下一个服务器。但是,当服务器的 ping 超时时,程序将完全停止,而不仅仅是移动到列表中的下一台服务器。我该如何解决这个问题?

以下是相关的代码片段(${ALS_HOSTS}是要ping的服务器列表(:

while read hostid
do
ping -c ${NUM_PING_PACKETS} ${hostid}
if ping -w ${TIMEOUT} -c ${NUM_PING_PACKETS} ${hostid} | grep ' from' 2>/dev/null 1>&2 # check for output
then
ssh ${hostid} uptime > ${WORKDIR}/${hostid} &
fi
done  < ${ALS_HOSTS}

(此脚本将在目前无法升级或重新配置的 CentOS 5 机器上运行(

这可能是因为sshwhile read循环共享 stdin,并耗尽所有数据以将其发送到远程主机。

使用ssh -n来防止这种情况:

ssh -n ${hostid} uptime > ${WORKDIR}/${hostid} &

最新更新