您的位置:首页 > 运维架构 > Shell

shell 实现并发操作

2015-02-26 20:06 232 查看
下面我们来模拟使用shell实现并发操作,有2个工作如下脚本所示:

work1.sh:

#!/bin/sh
echo "work1 start ......."
sleep 5
echo "work1 end .......
work2.sh

#!/bin/sh
echo "work2 start ......."
sleep 2
echo "work2 end .......
使用并发运行这2个work,concurrent_test.sh 

#/bin/sh
time=`date +%s`
#work1 sleep 5s
./work1.sh &
#$!是得到最后一个进程的id
i=$!
#work2 sleep 2s
./work2.sh &
j=$!
#wait是等待线程/进程结束,  用法 wait [id]   不带id代表等待所有子线程结束
wait
echo "work1 pid $i"
echo "work2 pid $j"
time=$((`date +%s` - $time))
echo "cost time: $time s"
运行结果:./concurrent_test.sh 
work1 start .......
work2 start .......
work2 end .......
work1 end .......
work1 pid 5663
work2 pid 5665
cost time: 5 s
两个work同时运行,花费时间5s。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  linux