!/bin/bash
time=echo 执行前时间$(date +"%H:%M.%S")
脚本执行前写空该文件
$0.log
$$是当前脚本的进程号,后面fifo是起个名而已
tmp_fifofile="$$.fifo"
创建命名管道符
mkfifo $tmp_fifofile
exec <> 是把管道符的标准输入输出和6号fd绑定,6是自定义的,随便取(取值注意:0是标准输入,1是标准输出,2是错误输出)
fd 就是 文件句柄(每打开一个文件,就会自动生成一个fd)
exec 6<>pipe文件 就是让6号文件描述符有管道的所有特性
exec 6<>$tmp_fifofile
rm $tmp_fifofile
thread_num=255
create key
for ((i=0;i<${thread_num};i++));do
echo
这个echo是输入thread_num个空行到 fd里
就相当于管道了有255个空行, 也就是最大只能并发255个进程
由下面那个for去读取空行,读取完,然后再写进去个空行
done >&6 #这是子线程清除
for i in {1..1000}
注,这个取值如果大于上面定义的区间,就会导致:第一批瞬间读取了255个空行,里面已经没有了内容可以读了,就会管道就会堵塞,直到,每个进程的运行完,再写进去一个空行,才能继续从管道里读取一个,接着再分叉一个进程
假如有1000个要并发的进程,你要控制最多只能运行255个的时候,255个运行完了,不写入空行到里面,就会一直阻塞,剩下745就会一直阻塞(运行不了,直到你给脚本发一个kiil 9信号,结束),因为这个脚本有写,所以就是说前面255执行完了,需要等255中执行完毕释放后255以后的才会得到执行。
do
每次从管道里读取一个空行,如循环一次后还剩254个空行可以消费(上面定义的同时最多可以消费255个)
read -u6 #如果不能理解,下面有个图单独说明这个
{
ip="192.168.198.$i"
echo $ip
a=ping -c 100 $ip|grep "100% packet loss"
判断ping是否有上面100%这些内容,如果有则up。
if [ "$a" == "" ]
then
echo "$ip network is up" >> $0.log
else
echo "$ip network is error" >>$0.log
fi
echo >&6:{}&中的代码执行完,再写入一个空行
echo >&6
} &
done
wait
echo $time
echo 全部后台完成时间$(date +"%H:%M.%S")
exec 6>&-;exec6<&- 都行,起释放作用,必须要有!
exec 6>$-
标签:空行,exec,ip,echo,管道,regress,255 From: https://www.cnblogs.com/zyk-2024/p/18388871