下面我会以ping主机是否能通的一个列子对并发进行说明。
===================================================================================
编写一个脚本,扫描192.168.198.0/24网络里,当前在线的主机有哪些,能ping通就认为在线。
单命令就是只有一条命令输出结果,没有多条命令相互依赖的情况。
执行原理就是直接把该命令放后台,这个程序的所有过程都同步进行,无需等待上一个命令执行完毕!
普通脚本
编写一个脚本,扫描192.168.198.0/24网络里,当前在线的主机有哪些,能ping通就认为在线,下面脚本是一个最简单且只显示ping得通的ip,代码和执行结果如下:
[root@controller ccx]# cat ping2.sh
for i in {128…133};do
ip=“192.168.198.$i”
ping -c 2 $ip &> /dev/null && echo $ip is up
done
echo “END”
[root@controller ccx]# sh ping2.sh
192.168.198.129 is up
192.168.198.130 is up
END
[root@controller ccx]#
注:如上代码执行过程中不能ctrl+c结束,必须用ctrl+z转入后台的形式结束。
如上代码,实现过程是一条一条依次出现的,所以上面6个IP花了大概30秒,如果60个600个IP花的时间可想而知。
多并发脚本
我们对上普通代码加上 多并发格式即可,&和wait,代码和执行结果如下:
[root@controller ccx]# cat ping2.sh
for i in {128…133};do