bash fifo管道使用测试例子

时间:2023-03-10 03:41:10
bash fifo管道使用测试例子

碰到一个场景:

一个脚本内起了多个后台线程,往一个日志文件写日志,结果因为线程之间争抢写锁,导致脚本执行效率很低,为了解决这个问题,希望减少写锁的争抢,尝试使用fifo解决该问题,以下是实验用例子。

#!/bin/bash
fifo_file=fifo.pipe
mkfifo $fifo_file
exec <>$fifo_file
rm $fifo_file
# 随便一个写了一个生成数据的函数
DateWrite ()
{
i=
while [ $i -lt ]
do
str=`date`
i=$(( i+ ))
echo "$i $str"
done
}
# 起100个后台线程,往管道写数据
for (( i=; i<; i++ ))
do
( DateWrite >& ) &
done #以下逻辑用于一直从管道中读取数据
while read date_time
do
echo $date_time >> output.file
done <&