下面给大家介绍的关于实现Linux BASH多进程并行处理的方法详解,你可能还不知道,下面我门一起来看看,希望对需要的朋友有所帮助! #!/bin/bashSEND_THREAD_NUM=13 tmp_fifofile="/tmp/$$.fifo" # 脚本运行的当前进程ID号作为文件名 mkfifo “$tmp_fifofile" # 新建一个随机fifo管道文件 exec 6<>"$tmp_fifofile" # 定义文件描述符6指向这个fifo管道文件 rm $tmp_fifofile for ((i=0;i<$SEND_THREAD_NUM;i++));do echo # for循环 往 fifo管道文件中写入13个空行 done >&6 for i in `seq 100`;do # 100 次 for 循环 开始 read -u6 # 从文件描述符6中读取行(实际指向fifo管道) { echo $i # 打印 i sleep 3 # 暂停3秒 echo >&6 # 再次往fifo管道文件中写入一个空行。 } & # {} 这部分语句被放入后台作为一个子进程执行,所以不必每次等待3秒后执行 #下一个,这部分的echo $i几乎是同时完成的,当fifo中13个空行读完后 for循环 # 继续等待 read 中读取fifo数据,当后台的13个子进程等待3秒后,按次序 # 排队往fifo输入空行,这样fifo中又有了数据,for语句继续执行 pid=$! #打印最后一个进入后台的子进程id echo $pid done wait exec 6>&- #删除文件描述符6 exit 0 以上关于实现Linux BASH多进程并行处理的方法详解就是小编为大家收集整理的全部内容了,希望对大家有所帮助。如果您喜欢这篇文章,可以收藏或分享给您的小伙伴们吧!欢迎持续关注我们的后续更新。 |
免责声明:本站部分文章和图片均来自用户投稿和网络收集,旨在传播知识,文章和图片版权归原作者及原出处所有,仅供学习与参考,请勿用于商业用途,如果损害了您的权利,请联系我们及时修正或删除。谢谢!
始终以前瞻性的眼光聚焦站长、创业、互联网等领域,为您提供最新最全的互联网资讯,帮助站长转型升级,为互联网创业者提供更加优质的创业信息和品牌营销服务,与站长一起进步!让互联网创业者不再孤独!
扫一扫,关注站长网微信