Skip to main content

提交作业

集群使用作业调度系统管理所有计算作业,该系统接受用户的作业请求,并将作业合理的分配到合适的节点上运行,因此所有用户均应通过作业调度系统提交计算作业,不可直接在任何节点上直接运行。用户使用 bsub 命令向作业调度系统提交作业, bsub 可用参数非常繁多,可对作业进行非常细致的控制,这里简要介绍常用参数和方法。

bsub 使用方式

命令行方式

bsub [options] command [arguments]

  • [options] 为 bsub 的参数,可以设定队列、CPU核数等
  • command 为计算程序,如果是 MPI 并行程序需要使用 mpirun 启动
  • [arguments] 为计算程序的参数

例:提交一个作业到 e5v3ib 队列,需要24核的 MPI 并行程序

[yaoge123]$ bsub -q e5v3ib -n 24 mpirun ./app
Job <3206000> is submitted to queue <e5v3ib>.

脚本方式

bsub < jobfile

jobfile 为作业的 shell 脚本文件,文件名任意且不需要运行权限,脚本内容如下:

#BSUB [options]
command [arguments]

脚本中以 #BSUB 开头的行后跟 bsub 的参数,其它行为作业运行脚本

例:提交一个作业到 e5v3ib 队列,需要48核,需要大内存节点,作业名为 MgSiO3,标准输出文件为 out,标准错误输出文件为 err,Intel MPI 的并行作业

[yaoge123]$ cat job.lsf 
#BSUB -q e5v3ib
#BSUB -n 48
#BSUB -J MgSiO3
#BSUB -o out
#BSUB -e err
module load ips/2018u4
mpirun ./app

[yaoge123]$ bsub < job.lsf 
Job <3207099> is submitted to queue <e5v3ib>.

等价如下命令行方式

[yaoge123]$ bsub -q e5v3ib -n 48 -J MgSiO3 -o out -e err "module load ips/2018u4;mpirun ./app"
Job <3207099> is submitted to queue <e5v3ib>.

bsub 常用参数

  • -n min_proc[,max_proc]:作业需要CPU核数;例:需要四核 -n 4;-n 4,8, 需要4~8核均可
  • -J job_name:作业名称
  • -I:交互式作业,可在作业运行期间和程序进行交互(如输入参数等),可在调试期间使用,正常计算请勿使用
  • -m:作业运行的节点或节点组,多个节点写在双引号内并用空格分隔,节点组对应的具体节点可用 bmgroup 命令查看,此参数很复杂。在 hostname/hostgroup 前后可用这些符号:后加 ! 指定头结点、后加 +[num] 指定节点使用顺序、前加 ~ 指定不使用这个节点。例:指定在 c04n01 和 c04n02 运行 -m "c04n01 c04n02";指定可在 f01n01~n03,但是最希望在 f01n01、次希望在 f01n02 -m "f01n01+2 f01n02+1 f01n03";
  • -R "res_req":资源请求串,此参数非常复杂;例:有的队列某些节点内存较大,需要大内存节点可以指定 -R largemem
  • -W [hour:]minute:作业运行最长时间,超过这个时间则被 kill
  • -x:作业需要独占节点,无论申请多少核,作业均独占所运行的节点,只有!队列支持此参数
  • -K:等待作业执行完才返回
  • -i input_file:标准输入文件
  • -o output_file:标准输出文件
  • -e error_file:标准错误输出文件
  • 以上三个参数的文件名中可以包含 %J 用于表示 JOBID。如果没有用 -o 或 -oo 指定标准输出文件,那么系统会自动设定为 output_%J;如不想要输出文件请设置 -o /dev/null

作业脚本示例

串行作业

  提交一个串行作业到 e52660 队列,命令行方式和脚本方式分别为:

[yaoge123]$ bsub -q e52660 ./app
Job <3279929> is submitted to queue <e52660>.
[yaoge123]$ cat job.lsf 
#BSUB -q e52660
./app

[yaoge123]$ bsub < job.lsf 
Job <3279930> is submitted to queue <e52660>.

MPI 并行作业

  MPI程序需要使用mpirun启动

  提交一个需要48核的 Intel MPI 并行作业到 e5v3ib,命令行方式为:

[yaoge123]$ bsub -q e5v3ib -n 48 "module load ips/2018u4;mpirun ./app"
Job <3280120> is submitted to queue <e5v3ib>.

  提交一个需要48核的 Open MPI 并行作业到 e5v3ib,脚本方式为:

[yaoge123]$ cat job.lsf 
#BSUB -q e5v3ib
#BSUB -n 48
module load iccifort/15.0.3 imkl/11.2.3 openmpi/1.10.0-iccifort-15.0.3
mpirun ./app

[yaoge123]$ bsub < job.lsf 
Job <3280122> is submitted to queue <e5v3ib>.

OpenMP 并行作业

  OpenMP 不能跨节点,因此 -n 不能指定超过一个节点的CPU核数

  提交一个需要64核的 OpenMP 并行作业到 e7v4ib,使用程序参数 -nt 指定线程数量,命令行方式为:

[yaoge123]$ bsub -q e7v4ib -n 64 "./app-nt \$LSB_DJOB_NUMPROC"
Job <3348175> is submitted to queue <e7v4ib>.

  提交一个需要64核的 OpenMP 并行作业到 e7v4ib,使用环境变量 OMP_NUM_THREADS 指定线程数量,脚本方式为:

[yaoge123]$ cat job.lsf 
#BSUB -q e7v4ib
#BSUB -n 64
OMP_NUM_THREADS="$LSB_DJOB_NUMPROC"
./app

[yaoge123]$ bsub < job.lsf 
Job <3348182> is submitted to queue <e7v4ib>.