Shell并发控制
第一节-文件描述符
如果文件没有被释放,就算文件被删了,文件描述符依然在;文件描述符又叫做句柄
5 < 表示5是输入文件句柄
5 > 表示5是输出文件句柄
5 <> 表示5是输入和输出文件句柄
# 用文件描述符打开文件,编号为6
exec 6 filename
# 显示文件描述符
ll /proc/$$/fd
# 关闭文件:释放文件句柄
exec 6 >&-
第二节-管道
在第一个命令产生输出的同时,输出会被立即送给第二个命令。数据传输不会用到任何中间文件或缓冲区。
command1 | command2
rpm -qa | sort | more
rpm -qa | sort > rpm.list
第三节-实例
多并发ping主机
#ping 主机会很慢,效果有影响
# !/bin/bash
#$$表示当前pid
thread=5 #线程数量
tmp_fifofile=/tmp/$$.fifo #存放线程的文件,.fifo文件为先进先出文件
mkfifo $tmp_fifofile
exec 8<> $tmp_fifofile
rm $tmp_fifofile
for i in `seq $thread`
do
echo $i &> 8
done
for i in {1..245}
do
read -u8
{
ip=192.168.122.$i
ping -c1 -W1 $ip &>/dev/null
if [ $? -eq 0 ];then
echo "$ip is down!"
else
echo "$ip is up"
fi
echo $i >& 8
}&
done
wait
#释放文件描述符的读和写
exec 8 >&-
exec 8 <&-
echo "all finished......"