半城风月半城雪 2021-03-29 11:01 采纳率: 50%
浏览 31

linux fifo 并发量控制

用fifo控制并发数量,一次同时后台运行两个。运行时间比较长,其中一个运行完之后,又启动了两个进程,这样就同时有3个了,

#!bin/bash
#exec clear file
mkdir -p xxx
thread_num=2

[ ! -p tmp ] && mkfifo tmp
exec 9<>tmp

for ((i=0;i<$thread_num;i++)); do
    echo >&9
done
echo "================start sh===================="
for i in  `cat shfiles.txt`;
do
        read -u 9
        {
         
        
                sh $i
                mv $i xxx/
                echo >&9
        } &
done
wait
exec 9>&-
rm tmp
echo "=================done===================="
exit 0
  • 写回答

1条回答 默认 最新

  • 半城风月半城雪 2022-02-08 17:31
    关注

    这个方法不行,老是莫名的多一个,又多一个,最后用了别的方法

    评论

报告相同问题?

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效