比如我们去测试某个网段内部可以ping通的主机,这个时候我们若采用传统的串行执行的方式,利用for循环对每个IP进行ping测试,其结果无疑是很慢的,因为我们需要为每个主机都发送ping包,有的时候主机ping不通的情况下,等待时间比ping通的时间更长。
所以可以采用多任务并发的操作,还是上面的例子,因为for循环时需要等待前面一个循环体内部命令执行完毕之后,才能执行下一次的循环体,所以我们可以将循环体内部的命令挂入到后台执行,这样就可以将多个循环体挂入后台执行,实现多任务并发。
#!/bin/bash
read -p "请输入网段(如192.168.1):" net
for var in {1..255}
do
ping ${net}.${var} -c 3 -i 0.5 -w 3 &>/dev/null &&echo ${net}.${var}>>/checklist.txt &
done
如这个脚本,我将ping主机的相关命令放在后台执行。因为其并发执行所以其速度也有一定程度的上升
总结:
shell不支持多进程
并发执行主要时将程序放入后台执行
若并发执行的命令过多,则其系统资源会被耗费殆尽