[英]Execute multiple scripts in parallel using shell script
通常我使用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
中的同一目录中并执行shellscripts
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):
我认为,你的问题是工人们一个接一个地被执行而不是同时被执行。 当像以前一样在不同终端中启动所有三个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 ,您可以这样称呼一个subshell。 也许在背景中使用&
像这样开始所有这些都是有帮助的:
( python path/to/first/worker/FirstWorker.py ) &
( python path/to/second/worker/SecondWorker.py ) &
( python path/to/client/Client.py ) &
你甚至可以重定向工人的输出,但我不确定如何做到这一点...希望它有帮助......
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.