Shell脚本中的并发

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Shell脚本中的并发相关的知识,希望对你有一定的参考价值。

主要记录一下Shell脚本中的命令的并发和串行执行。

默认的情况下,Shell脚本中的命令是串行执行的,必须等到前一条命令执行完后才执行接下来的命令,但是如果我有一大批的的命令需要执行,而且互相又没有影响的情况下(有影响的话就比较复杂了),那么就要使用命令的并发执行了。


看下面的代码:

  1. #!/bin/bash  

  2.   

  3. for(( i = 0; i < ${count}; i++ ))  

  4. do  

  5.         commands1  

  6. done  

  7.   

  8. commands2  


对于上面的代码,因为每个commands1都挺耗时的,所以打算使用并发编程,这样就可以节省大量时间了。


修改后的代码如下:


  1. #!/bin/bash  

  2.   

  3. for(( i = 0; i < ${count}; i++ ))  

  4. do  

  5. {  

  6.         commands1  

  7. }&  

  8. done  

  9.   

  10. commands2  


这样的话commands1就可以并行执行了。 实质是将commands1作为后台进程在执行,这样主进程就不用等待前面的命令执行完毕之后才开始执行接下来的命令。

但是我的本来目的是让commands1的这个循环都执行结束后,再用command2去处理前面的结果。如果像上面这样写的话,在commands1都还没结束时就已经开始执行commands2了,得到了错误的结果。

再次修改代码如下:

  1. #!/bin/bash  

  2.   

  3. for(( i = 0; i < ${count}; i++ ))  

  4. do  

  5. {  

  6.         commands1  

  7. }&  

  8. done  

  9. wait  

  10.   

  11. commands2  


上面这样就可以达到预期的目的了,先是所有的commands1在后台并行执行,等到循环里面的命令都结束之后才执行接下来的commands2。


对于上面的代码,如果count值特别大的时候,我们应该控制并发进程的个数,不然会影响系统其他进程的运行,甚至死机。



本文出自 “Linux Oracle MariaDB” 博客,请务必保留此出处http://wangergui.blog.51cto.com/8504247/1926470

以上是关于Shell脚本中的并发的主要内容,如果未能解决你的问题,请参考以下文章

shell多个脚本怎么并发执行

shell脚本并发

Linux下模拟多线程的并发并发shell脚本

shell脚本并发

Linux脚本学习案例shell脚本多通道并发执行存储过程

Linux用shell脚本监控网站运行状态并发告警邮件