28

我有一个 qsub 脚本作为

#####----submit_job.sh---#####
    #!/bin/sh
    #$ -N job1
    #$ -t 1-100
    #$ -cwd
    SEEDFILE=/home/user1/data1
    SEED=$(sed -n -e "$SGE_TASK_ID p" $SEEDFILE)
    /home/user1/run.sh $SEED 

问题是 - 它将所有错误和输出文件(job1.eJOBID 和 job1.oJOBID)放在我运行 qsub submit_job.sh 的同一目录中,而我想保存这些文件(输出和错误日志文件在相同的不同地点(指定为 $SEED_output)。我尝试将行更改为

/home/user1/run.sh $SEED -o $SEED_output

但它没有用。有什么建议吗??如何指定默认输出和错误日志文件的路径和名称?

4

3 回答 3

41

通常,错误和输出文件在 qsub 脚本中作为 pbs 指令给出,或者作为 qsub 脚本的命令行选项给出,如下所示:

#! /bin/bash
#PBS -q queue_name
#PBS -A account_name
#PBS -l nodes=12:ppn=12
#PBS -l walltime=18:00:00
#PBS -e /mypath/error.txt
#PBS -o /mypath/output.txt

或作为 qsub 的命令行选项,如下所示:

qsub -o /mypath/output.txt -e /mypath/error.txt submit_job.sh

对于第一个选项,我认为您不能使用变量,因为 shell 不会查看已注释的行。另外,我认为 PBS 在 shell 之前处理注释行。如果您在调用 qsub 时知道路径,则可以尝试第二个选项。或者,您可以尝试简单地重定向脚本本身的输出和错误:

/home/user1/run.sh $SEED > ${SEED}/output.txt 2> ${SEED}/error.txt

第三种选择可能是最简单的。输出和错误文件可能仍会在运行目录中创建,尽管它们可能是空的。

于 2012-02-02T19:26:32.433 回答
2

乍一看,您需要在 -o 声明中将变量括起来。

/home/user1/run.sh $SEED -o ${SEED}_output

否则 bash 正在寻找一个名为 ${SEED_output} 的变量,该变量不存在。

于 2012-02-01T20:13:13.780 回答
0

我遇到了同样的问题。我的解决方法是:

#$ -N script-name
#$ -wd <path-to-project>/log 
cd ..

在 qsub 脚本中。现在错误和输出文件被保存<path-to-project>/log 并且脚本可以工作<path-to-project> 至少对我来说有效

于 2021-03-13T07:22:37.840 回答