在一个Shell脚本中同时执行多个脚本

本文讲述了用户在不同终端中使用Python启动Gearmanworker时遇到的问题,包括文件路径错误和顺序执行脚本。文章提供了解决方案,包括使用GNUParallel、&运算符和nohup命令进行并行执行。

通常,人们在不同的终端中使用python命令启动两个不同的gearman worker,在这些gearman worker准备就绪后,执行客户端文件向两个侦听worker发送请求。人们尝试将这三个命令都放在shellscript中并一次执行它们,但无法实现。下面是尝试过的不同方法以及遇到的问题:
在这里插入图片描述

(1)将所有命令放在一个shell脚本中:

#!/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'

(2)将python命令放在同一个目录中的.sh文件中,然后执行shell脚本:

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

遇到问题:

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. 解决方案

为了解决上述问题,可以采用以下解决方案:

(1)使用并行处理库(如GNU Parallel)来并行执行脚本。GNU Parallel是一个用于并行执行命令的命令行工具,它可以很容易地将多个命令放在一起并行执行。

(2)使用shell内置的"&“运算符来并行执行脚本。”&"运算符可以将命令放在后台执行,这样就可以同时执行多个命令。

(3)使用shell的"nohup"命令来并行执行脚本。"nohup"命令可以将命令放在后台执行,即使终端关闭也不会中断命令的执行。

下面是一个使用GNU Parallel并行执行脚本的示例:

parallel -j 2 python /root/Desktop/karim/temp_git/ATD_final/ATD_allClass/classifier_allClass.py ::: 1 2 3

这条命令将并行执行三个python脚本,每个脚本都使用不同的参数。

下面是一个使用shell内置的"&"运算符并行执行脚本的示例:

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 &

这条命令将并行执行三个python脚本,每个脚本都使用不同的参数。

下面是一个使用shell的"nohup"命令并行执行脚本的示例:

nohup python /root/Desktop/karim/temp_git/ATD_final/ATD_allClass/classifier_allClass.py &
nohup python /root/Desktop/karim/temp_git/ATD_final/ATD_lessClass/classifier_lessClass.py &
nohup python ans_type.py 1 &

这条命令将并行执行三个python脚本,每个脚本都使用不同的参数,即使终端关闭也不会中断命令的执行。

希望这些解决方案能够帮助人们并行执行多个脚本。

<think>我们写一个shell脚本,用于同时启动多个其他shell脚本。这可以通过在后台运行每个脚本(使用&)来实现,这样它们就可以并发执行。注意:如果脚本之间有依赖关系或需要顺序执行,则不适合使用此方法。这里我们假设可以同时启动。例如,假设我们有多个脚本:script1.sh,script2.sh,script3.sh,我们可以写一个master.sh来同时启动它们。步骤:1.确保要运行脚本具有可执行权限(chmod+xscript.sh)。2.在master.sh中,我们可以使用相对路径或绝对路径来调用这些脚本,并在每个命令后面加上&,使其在后台运行。示例master.sh内容: ```bash#!/bin/bash#启动script1.sh./script1.sh& #启动script2.sh./script2.sh& #启动script3.sh./script3.sh& #等待所有后台任务完成waitecho "所有脚本执行完毕"```解释:-每个脚本后面加上&,表示在后台运行,这样脚本会并行执行。 -使用wait命令,会等待所有后台进程都完成后再继续执行后面的命令(这里是打印完成信息)。注意:如果脚本位于不同的目录,需要写全路径。另外,我们也可以使用一个循环来启动多个脚本,例如: ```bash#!/bin/bashscripts=("script1.sh" "script2.sh""script3.sh") forscript in"${scripts[@]}"; do./"$script" &donewaitecho "所有脚本执行完毕" ```这样更便于管理多个脚本。请根据实际情况调整脚本路径和名称。§§相关问题§§1.如果某些脚本需要在前一个脚本成功启动后才能启动,应如何修改脚本?2.如何记录每个启动脚本的日志,并将输出重定向到不同的日志文件?3.如何控制同时运行脚本数量,以避免资源耗尽?4.如果某个脚本启动失败(返回非零退出码),如何让主脚本立即停止并退出?5.在Windows环境下,是否有类似的方式可以同时启动多个批处理脚本?</think>以下是一个可以同时启动多个Shell脚本的示例脚本,并解释其工作原理: ```bash #!/bin/bash # 要并行执行脚本列表 scripts=("script1.sh" "script2.sh" "script3.sh" "script4.sh") # 存储所有后台进程ID pids=() # 循环启动所有脚本 for script in "${scripts[@]}"; do # 检查脚本是否存在 if [[ ! -f "$script" ]]; then echo "错误: 找不到脚本 $script" exit 1 fi # 在后台执行脚本并记录PID ./"$script" & pids+=($!) echo "已启动 $script (PID: $!)" done # 等待所有后台任务完成 echo "等待所有脚本执行完成..." for pid in "${pids[@]}"; do wait "$pid" status=$? echo "进程 $pid 已完成,退出状态码: $status" done echo "所有脚本执行完毕!" ``` ### 使用说明: 1. 将需要并行执行脚本名称添加到 `scripts` 数组中 2. 给本脚本添加执行权限:`chmod +x master_script.sh` 3. 运行脚本:`./master_script.sh` ### 工作原理: 1. **并行执行**:使用 `&` 操作符将每个脚本放入后台执行 2. **进程跟踪**:通过 `$!` 获取每个后台进程的PID 3. **等待完成**:使用 `wait` 命令等待所有子进程结束 4. **状态监控**:捕获并显示每个脚本的退出状态码 ### 注意事项: - 脚本应在同一目录下,或使用绝对路径 - 使用 `wait` 会阻塞直到所有后台任务完成 - 输出可能会混合,如需分离输出可重定向到不同文件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值