使用shell脚本并行执行多个脚本

时间:2015-02-13 11:35:30

标签: python linux bash shell

通常我使用python命令在不同的终端启动两个不同的齿轮工人,一旦那些齿轮工人准备好,我执行客户端文件,向两个听力工作人员发送请求。

我试图将所有三个命令放在一个shellcript中并一次执行它们,但不能

#!/bin/sh
python /root/Desktop/karim/temp_git/ATD_final/ATD_allClass/classifier_allClass.py
python /root/Desktop/karim/temp_git/ATD_final/ATD_lessClass/classifier_lessClass.py
python ans_type.py 1

给出:

folders = [f for f in sorted(listdir(container_path))
OSError: [Errno 2] No such file or directory: '/root/Desktop/karim/temp_git/ATD_final/ATD_pylink/trec_data'

之后我尝试将此python命令放在.sh中的同一目录中并执行shellcripts

allClass.sh:

#!/bin/sh
python /root/Desktop/karim/temp_git/ATD_final/ATD_allClass/classifier_allClass.py

lessClass.sh

python /root/Desktop/karim/temp_git/ATD_final/ATD_lessClass/classifier_lessClass.py

并在final.sh中:

#!/bin/sh
sh /root/Desktop/karim/temp_git/ATD_final/ATD_allClass/allClass.sh
sh /root/Desktop/karim/temp_git/ATD_final/ATD_lessClass/less_lessClass.py
python ans_type.py 1

final.sh

#!/bin/sh
sh /root/Desktop/karim/temp_git/ATD_final/ATD_allClass/allClass.sh
sh /root/Desktop/karim/temp_git/ATD_final/ATD_lessClass/less_lessClass.py
python ans_type.py 1

给出:

sh: 0: Can't open /root/Desktop/karim/temp_git/ATD_final/ATD_allClass/allClass.sh
link-grammar: Info: Dictionary found at /usr/share/link-grammar/en/4.0.dict
Traceback (most recent call last):

1 个答案:

答案 0 :(得分:0)

我认为,你的问题是工人们一个接一个地被处决,而不是同时被处决。当你像以前一样在不同的终端启动所有三个python脚本时,它们会同时执行。您可能想尝试在一个bash脚本中启动三个脚本,但是有三个不同的子shell。 即:

( python path/to/first/worker/FirstWorker.py )
( python path/to/second/worker/SecondWorker.py )
( python path/to/client/Client.py )

根据http://www.tldp.org/LDP/abs/html/subshells.html,您可以像这样调用子shell。也许在后台使用&开始所有这些操作甚至会有所帮助:

( python path/to/first/worker/FirstWorker.py ) &
( python path/to/second/worker/SecondWorker.py ) &
( python path/to/client/Client.py ) &

你甚至可以重定向工人的输出,但我不确定如何做到这一点......希望它有所帮助......