Helix/Slurm: Difference between revisions
S Richling (talk | contribs) Tag: Manual revert |
H Winkhardt (talk | contribs) (Update Source Tags) |
||
(22 intermediate revisions by 3 users not shown) | |||
Line 28: | Line 28: | ||
Batch jobs are submitted with the command: |
Batch jobs are submitted with the command: |
||
< |
<syntaxhighlight lang="bash">$ sbatch <job-script> </syntaxhighlight> |
||
A job script contains options for Slurm in lines beginning with #SBATCH as well as your commands which you want to execute on the compute nodes. For example: |
A job script contains options for Slurm in lines beginning with #SBATCH as well as your commands which you want to execute on the compute nodes. For example: |
||
<syntaxhighlight lang="slurm">#!/bin/bash |
|||
<source lang='bash'> |
|||
⚫ | |||
#!/bin/bash |
|||
⚫ | |||
#SBATCH --ntasks=1 |
#SBATCH --ntasks=1 |
||
#SBATCH --time=00:20:00 |
#SBATCH --time=00:20:00 |
||
Line 40: | Line 39: | ||
#SBATCH --export=NONE |
#SBATCH --export=NONE |
||
echo 'Hello world' |
echo 'Hello world' |
||
</syntaxhighlight> |
|||
</source> |
|||
This jobs requests one core (--ntasks=1) and 1 GB memory (--mem=1gb) for 20 minutes (--time=00:20:00) on nodes provided by the partition 'single'. |
This jobs requests one core (--ntasks=1) and 1 GB memory (--mem=1gb) for 20 minutes (--time=00:20:00) on nodes provided by the partition 'cpu-single'. |
||
For the sake of a better reproducibility of jobs it is recommended to use the option --export=NONE to prevent the propagation of environment variables from the submit session into the job environment and to load required software modules in the job script. |
For the sake of a better reproducibility of jobs it is recommended to use the option --export=NONE to prevent the propagation of environment variables from the submit session into the job environment and to load required software modules in the job script. |
||
Line 50: | Line 49: | ||
On bwForCluster Helix it is necessary to request a partition with '--partition=<partition_name>' on job submission. Within a partition job allocations are routed automatically to the most suitable compute node(s) for the requested resources (e.g. amount of nodes and cores, memory, number of GPUs). The devel partition is the default partition, if no partition is requested. |
On bwForCluster Helix it is necessary to request a partition with '--partition=<partition_name>' on job submission. Within a partition job allocations are routed automatically to the most suitable compute node(s) for the requested resources (e.g. amount of nodes and cores, memory, number of GPUs). The devel partition is the default partition, if no partition is requested. |
||
The partitions devel and single are operated in shared mode, i.e. jobs from different users can run on the same node. Jobs can get exclusive access to compute nodes in these partitions with the "--exclusive" option. The partitions cpu-multi and gpu-multi are operated in exclusive mode. Jobs in these partitions automatically get exclusive access to the requested compute nodes. |
The partitions devel, cpu-single and gpu-single are operated in shared mode, i.e. jobs from different users can run on the same node. Jobs can get exclusive access to compute nodes in these partitions with the "--exclusive" option. The partitions cpu-multi and gpu-multi are operated in exclusive mode. Jobs in these partitions automatically get exclusive access to the requested compute nodes. |
||
GPUs are requested with the option "--gres=gpu:<number-of-gpus>". |
GPUs are requested with the option "--gres=gpu:<number-of-gpus>". |
||
Line 68: | Line 67: | ||
| nodes=2, time=00:30:00 |
| nodes=2, time=00:30:00 |
||
|- |
|- |
||
| single |
| cpu-single |
||
| shared |
| shared |
||
| cpu, fat |
| cpu, fat |
||
| ntasks=1, time=00:30:00, mem-per-cpu=2gb |
|||
| nodes=1, time=120:00:00 |
|||
|- |
|||
| gpu-single |
|||
| shared |
|||
| gpu4, gpu8 |
|||
| ntasks=1, time=00:30:00, mem-per-cpu=2gb |
| ntasks=1, time=00:30:00, mem-per-cpu=2gb |
||
| nodes=1, time=120:00:00 |
| nodes=1, time=120:00:00 |
||
Line 105: | Line 110: | ||
== Examples == |
== Examples == |
||
Here you can find some example scripts for batch jobs. |
Here you can find some example scripts for batch jobs. |
||
=== Serial Programs === |
=== Serial Programs === |
||
< |
<syntaxhighlight lang="slurm"> |
||
#!/bin/bash |
#!/bin/bash |
||
#SBATCH --partition=single |
#SBATCH --partition=cpu-single |
||
#SBATCH --ntasks=1 |
#SBATCH --ntasks=1 |
||
#SBATCH --time=20:00:00 |
#SBATCH --time=20:00:00 |
||
#SBATCH --mem=4gb |
#SBATCH --mem=4gb |
||
./my_serial_program |
./my_serial_program |
||
</syntaxhighlight> |
|||
</source> |
|||
'''Notes:''' |
'''Notes:''' |
||
* Jobs with "--mem" up to 236gb can run on all node types associated with the single partition. |
* Jobs with "--mem" up to 236gb can run on all node types associated with the cpu-single partition. |
||
=== Multi-threaded Programs === |
=== Multi-threaded Programs === |
||
< |
<syntaxhighlight lang="slurm"> |
||
#!/bin/bash |
#!/bin/bash |
||
#SBATCH --partition=single |
#SBATCH --partition=cpu-single |
||
#SBATCH --nodes=1 |
#SBATCH --nodes=1 |
||
#SBATCH --ntasks-per-node=1 |
#SBATCH --ntasks-per-node=1 |
||
Line 133: | Line 138: | ||
export OMP_NUM_THREADS=${SLURM_CPUS_PER_TASK} |
export OMP_NUM_THREADS=${SLURM_CPUS_PER_TASK} |
||
./my_multithreaded_program |
./my_multithreaded_program |
||
</syntaxhighlight> |
|||
</source> |
|||
'''Notes:''' |
'''Notes:''' |
||
* Jobs with "--ntasks-per-node" up to 64 and "--mem" up to 236gb can run on all node types associated with the single partition. |
* Jobs with "--ntasks-per-node" up to 64 and "--mem" up to 236gb can run on all node types associated with the cpu-single partition. |
||
* With "export OMP_NUM_THREADS=${SLURM_CPUS_PER_TASK}" you can set the number of threads according to the number of resources requested. |
* With "export OMP_NUM_THREADS=${SLURM_CPUS_PER_TASK}" you can set the number of threads according to the number of resources requested. |
||
=== MPI Programs === |
=== MPI Programs === |
||
< |
<syntaxhighlight lang="slurm"> |
||
#!/bin/bash |
#!/bin/bash |
||
#SBATCH --partition=cpu-multi |
#SBATCH --partition=cpu-multi |
||
Line 147: | Line 152: | ||
#SBATCH --ntasks-per-node=64 |
#SBATCH --ntasks-per-node=64 |
||
#SBATCH --time=12:00:00 |
#SBATCH --time=12:00:00 |
||
#SBATCH --mem=50gb |
|||
module load compiler/gnu |
module load compiler/gnu |
||
module load mpi/openmpi |
module load mpi/openmpi |
||
srun ./my_mpi_program |
srun ./my_mpi_program |
||
</syntaxhighlight> |
|||
</source> |
|||
'''Notes:''' |
'''Notes:''' |
||
Line 160: | Line 164: | ||
=== GPU Programs === |
=== GPU Programs === |
||
< |
<syntaxhighlight lang="slurm"> |
||
#!/bin/bash |
#!/bin/bash |
||
#SBATCH --partition=single |
#SBATCH --partition=gpu-single |
||
#SBATCH --nodes=1 |
#SBATCH --nodes=1 |
||
#SBATCH --ntasks-per-node=40 |
#SBATCH --ntasks-per-node=40 |
||
Line 171: | Line 175: | ||
export OMP_NUM_THREADS=${SLURM_NTASKS} |
export OMP_NUM_THREADS=${SLURM_NTASKS} |
||
./my_cuda_program |
./my_cuda_program |
||
</syntaxhighlight> |
|||
</source> |
|||
'''Notes:''' |
'''Notes:''' |
||
Line 182: | Line 186: | ||
** A100 GPUs offer better performance for double precision computations or if the code makes use of tensor cores. |
** A100 GPUs offer better performance for double precision computations or if the code makes use of tensor cores. |
||
* The Cuda module used for compilation must be loaded before the start of the program. |
* The Cuda module used for compilation must be loaded before the start of the program. |
||
=== More examples === |
|||
Further batch script examples are available on bwForCluster Helix in the directory: <code>/opt/bwhpc/common/system/slurm-examples</code> |
|||
= Interactive Jobs = |
= Interactive Jobs = |
||
Interactive jobs must NOT run on the |
Interactive jobs must NOT run on the login nodes, however resources for interactive jobs can be requested using srun. The following example requests an interactive session on 1 core for 2 hours: |
||
< |
<syntaxhighlight lang="bash">$ salloc --partition=cpu-single --ntasks=1 --time=2:00:00 </syntaxhighlight> |
||
After execution of this command wait until the queueing system has granted you the requested resources. Once granted you will be automatically logged on the allocated compute node. |
After execution of this command wait until the queueing system has granted you the requested resources. Once granted you will be automatically logged on the allocated compute node. |
||
Line 193: | Line 201: | ||
If you use applications or tools which provide a GUI, enable X-forwarding for your interactive session with: |
If you use applications or tools which provide a GUI, enable X-forwarding for your interactive session with: |
||
< |
<syntaxhighlight lang="bash">$ salloc --partition=cpu-single --ntasks=1 --time=2:00:00 --x11 </syntaxhighlight> |
||
Once the walltime limit has been reached you will be automatically logged out from the compute node. |
Once the walltime limit has been reached you will be automatically logged out from the compute node. |
||
{| style="background:#FFE856; width:100%;" |
|||
| '''Known issue:''' If your interactive job does not start correctly, try with option "--reservation=interactive". |
|||
|} |
|||
= Job Monitoring = |
= Job Monitoring = |
||
Line 203: | Line 215: | ||
For an overview of your submitted jobs use the command: |
For an overview of your submitted jobs use the command: |
||
< |
<syntaxhighlight lang="bash">$ squeue</syntaxhighlight> |
||
⚫ | |||
⚫ | |||
⚫ | |||
'''Notes:'''<br> |
|||
⚫ | |||
A job start may be delayed for various reasons: |
|||
* (MaxCpuPerAccount) - There is a limit to how many CPU cores the members of a Rechenvorhaben can use at the same time. The job exceeds this limit. |
|||
* (MaxGRESPerAccount) - There is a limit to how many GPUs the members of a Rechenvorhaben can use at the same time. The job exceeds this limit. |
|||
* (QOSMinGRES) - The job was submitted to a gpu partition without requesting a GPU. |
|||
* (launch failed requeued held) - The job has failed to start. You may be able to resume it using scontrol. Alternatively you can cancel it and submit it again. |
|||
For further reasons please refer to: https://slurm.schedmd.com/job_reason_codes.html |
|||
== |
== Information about resource usage of running jobs == |
||
You can monitor the resource usage of running jobs with the sstat command. For example: |
You can monitor the resource usage of running jobs with the sstat command. For example: |
||
Line 225: | Line 245: | ||
It is also possible to attach an interactive shell to a running job with command: |
It is also possible to attach an interactive shell to a running job with command: |
||
< |
<syntaxhighlight lang="bash">$ srun --jobid=<jobid> --overlap --pty /bin/bash</syntaxhighlight> |
||
Commands like 'top' show you the most busy processes on the node. To exit 'top' type 'q'. |
Commands like 'top' show you the most busy processes on the node. To exit 'top' type 'q'. |
||
Line 234: | Line 254: | ||
You get feedback on resource usage and job efficiency for completed jobs with the command: |
You get feedback on resource usage and job efficiency for completed jobs with the command: |
||
< |
<syntaxhighlight lang="bash"> |
||
$ seff <jobid> |
$ seff <jobid> |
||
</syntaxhighlight> |
|||
</source> |
|||
Example Output: |
Example Output: |
||
< |
<syntaxhighlight lang="bash"> |
||
============================= JOB FEEDBACK ============================= |
============================= JOB FEEDBACK ============================= |
||
Job ID: 12345678 |
Job ID: 12345678 |
||
Line 253: | Line 273: | ||
Memory Utilized: 432.74 GB (estimated maximum) |
Memory Utilized: 432.74 GB (estimated maximum) |
||
Memory Efficiency: 85.96% of 503.42 GB (251.71 GB/node) |
Memory Efficiency: 85.96% of 503.42 GB (251.71 GB/node) |
||
</syntaxhighlight> |
|||
</source> |
|||
Explanation: |
Explanation: |
||
Line 273: | Line 293: | ||
To see the accounting data of a specific job: |
To see the accounting data of a specific job: |
||
< |
<syntaxhighlight lang="bash">$ sacct -j <jobid> --format=user,jobid,account,nnodes,ncpus,time,elapsed,AllocTRES%50</syntaxhighlight> |
||
To retrive the job history for a specific user for a certain time frame: |
To retrive the job history for a specific user for a certain time frame: |
||
< |
<syntaxhighlight lang="bash">$ sacct -u <user> -S 2022-08-20 -E 2022-08-30 --format=user,jobid,account,nnodes,ncpus,time,elapsed,AllocTRES%50</syntaxhighlight> |
||
= Overview about free resources = |
= Overview about free resources = |
||
Line 283: | Line 303: | ||
On the login nodes the following command shows what resources are available for immediate use: |
On the login nodes the following command shows what resources are available for immediate use: |
||
< |
<syntaxhighlight lang="bash">$ sinfo_t_idle</syntaxhighlight> |
Latest revision as of 14:31, 17 January 2025
General information about Slurm
The bwForCluster Helix uses Slurm as batch system.
- Slurm documentation: https://slurm.schedmd.com/documentation.html
- Slurm cheat sheet: https://slurm.schedmd.com/pdfs/summary.pdf
- Slurm tutorials: https://slurm.schedmd.com/tutorials.html
Slurm Command Overview
Slurm commands | Brief explanation |
---|---|
sbatch | Submits a job and queues it in an input queue |
saclloc | Request resources for an interactive job |
squeue | Displays information about active, eligible, blocked, and/or recently completed jobs |
scontrol | Displays detailed job state information |
sstat | Displays status information about a running job |
scancel | Cancels a job |
Job Submission
Batch jobs are submitted with the command:
$ sbatch <job-script>
A job script contains options for Slurm in lines beginning with #SBATCH as well as your commands which you want to execute on the compute nodes. For example:
#!/bin/bash
#SBATCH --partition=cpu-single
#SBATCH --ntasks=1
#SBATCH --time=00:20:00
#SBATCH --mem=1gb
#SBATCH --export=NONE
echo 'Hello world'
This jobs requests one core (--ntasks=1) and 1 GB memory (--mem=1gb) for 20 minutes (--time=00:20:00) on nodes provided by the partition 'cpu-single'.
For the sake of a better reproducibility of jobs it is recommended to use the option --export=NONE to prevent the propagation of environment variables from the submit session into the job environment and to load required software modules in the job script.
Partitions
On bwForCluster Helix it is necessary to request a partition with '--partition=<partition_name>' on job submission. Within a partition job allocations are routed automatically to the most suitable compute node(s) for the requested resources (e.g. amount of nodes and cores, memory, number of GPUs). The devel partition is the default partition, if no partition is requested.
The partitions devel, cpu-single and gpu-single are operated in shared mode, i.e. jobs from different users can run on the same node. Jobs can get exclusive access to compute nodes in these partitions with the "--exclusive" option. The partitions cpu-multi and gpu-multi are operated in exclusive mode. Jobs in these partitions automatically get exclusive access to the requested compute nodes.
GPUs are requested with the option "--gres=gpu:<number-of-gpus>".
Partition | Node Access Policy | Node Types | Default | Limits |
---|---|---|---|---|
devel | shared | cpu, gpu4 | ntasks=1, time=00:10:00, mem-per-cpu=2gb | nodes=2, time=00:30:00 |
cpu-single | shared | cpu, fat | ntasks=1, time=00:30:00, mem-per-cpu=2gb | nodes=1, time=120:00:00 |
gpu-single | shared | gpu4, gpu8 | ntasks=1, time=00:30:00, mem-per-cpu=2gb | nodes=1, time=120:00:00 |
cpu-multi | job exclusive | cpu | nodes=2, time=00:30:00 | nodes=32, time=48:00:00 |
gpu-multi | job exclusive | gpu4 | nodes=2, time=00:30:00 | nodes=8, time=48:00:00 |
Constraints
It is possible to request explicitly the CPU manufacturer of compute nodes with the option "--constraint=<constraint_name>".
Constraint | Meaning |
---|---|
amd | request AMD nodes (default) |
intel | request Intel nodes (when available) |
Examples
Here you can find some example scripts for batch jobs.
Serial Programs
#!/bin/bash
#SBATCH --partition=cpu-single
#SBATCH --ntasks=1
#SBATCH --time=20:00:00
#SBATCH --mem=4gb
./my_serial_program
Notes:
- Jobs with "--mem" up to 236gb can run on all node types associated with the cpu-single partition.
Multi-threaded Programs
#!/bin/bash
#SBATCH --partition=cpu-single
#SBATCH --nodes=1
#SBATCH --ntasks-per-node=1
#SBATCH --cpus-per-task=16
#SBATCH --time=01:30:00
#SBATCH --mem=50gb
export OMP_NUM_THREADS=${SLURM_CPUS_PER_TASK}
./my_multithreaded_program
Notes:
- Jobs with "--ntasks-per-node" up to 64 and "--mem" up to 236gb can run on all node types associated with the cpu-single partition.
- With "export OMP_NUM_THREADS=${SLURM_CPUS_PER_TASK}" you can set the number of threads according to the number of resources requested.
MPI Programs
#!/bin/bash
#SBATCH --partition=cpu-multi
#SBATCH --nodes=2
#SBATCH --ntasks-per-node=64
#SBATCH --time=12:00:00
module load compiler/gnu
module load mpi/openmpi
srun ./my_mpi_program
Notes:
- "--mem" requests the memory per node. The maximum is 236gb.
- The Compiler and MPI modules used for the compilation must be loaded before the start of the program.
- It is recommended to start MPI programs with 'srun'.
GPU Programs
#!/bin/bash
#SBATCH --partition=gpu-single
#SBATCH --nodes=1
#SBATCH --ntasks-per-node=40
#SBATCH --gres=gpu:4
#SBATCH --time=12:00:00
#SBATCH --mem=200gb
module load devel/cuda
export OMP_NUM_THREADS=${SLURM_NTASKS}
./my_cuda_program
Notes:
- The number of GPUs per node is requested with the option "--gres=gpu:<number-of-gpus>"
- It is recommended to request a suitable GPU type for your application with the option "--gres=gpu:<gpu-type>:<number-of-gpus>". For <gpu-type> put the 'GPU Type' listed in the last line of the Compute Nodes table.
- Example for a request of two A40 GPUs: --gres=gpu:A40:2
- Example for a request of one A100 GPU: --gres=gpu:A100:1
- If you are unsure, if your code will run faster on a A40 or a A100, please run a test case and compare the run times. In general the following applies:
- A40 GPUs are optimized for single precision computations.
- A100 GPUs offer better performance for double precision computations or if the code makes use of tensor cores.
- The Cuda module used for compilation must be loaded before the start of the program.
More examples
Further batch script examples are available on bwForCluster Helix in the directory: /opt/bwhpc/common/system/slurm-examples
Interactive Jobs
Interactive jobs must NOT run on the login nodes, however resources for interactive jobs can be requested using srun. The following example requests an interactive session on 1 core for 2 hours:
$ salloc --partition=cpu-single --ntasks=1 --time=2:00:00
After execution of this command wait until the queueing system has granted you the requested resources. Once granted you will be automatically logged on the allocated compute node.
If you use applications or tools which provide a GUI, enable X-forwarding for your interactive session with:
$ salloc --partition=cpu-single --ntasks=1 --time=2:00:00 --x11
Once the walltime limit has been reached you will be automatically logged out from the compute node.
Known issue: If your interactive job does not start correctly, try with option "--reservation=interactive". |
Job Monitoring
Information about submitted jobs
For an overview of your submitted jobs use the command:
$ squeue
To get detailed information about a specific job use the command:
$ scontrol show job <jobid>
Notes:
A job start may be delayed for various reasons:
- (MaxCpuPerAccount) - There is a limit to how many CPU cores the members of a Rechenvorhaben can use at the same time. The job exceeds this limit.
- (MaxGRESPerAccount) - There is a limit to how many GPUs the members of a Rechenvorhaben can use at the same time. The job exceeds this limit.
- (QOSMinGRES) - The job was submitted to a gpu partition without requesting a GPU.
- (launch failed requeued held) - The job has failed to start. You may be able to resume it using scontrol. Alternatively you can cancel it and submit it again.
For further reasons please refer to: https://slurm.schedmd.com/job_reason_codes.html
Information about resource usage of running jobs
You can monitor the resource usage of running jobs with the sstat command. For example:
$ sstat --format=JobId,AveCPU,AveRSS,MaxRSS -j <jobid>
This will show average CPU time, average and maximum memory consumption of all tasks in the running job.
'sstat -e' command shows a list of fields that can be specified with the '--format' option.
Interactive access to running jobs
It is also possible to attach an interactive shell to a running job with command:
$ srun --jobid=<jobid> --overlap --pty /bin/bash
Commands like 'top' show you the most busy processes on the node. To exit 'top' type 'q'.
To monitor your GPU processes use the command 'nvidia-smi'.
Job Feedback
You get feedback on resource usage and job efficiency for completed jobs with the command:
$ seff <jobid>
Example Output:
============================= JOB FEEDBACK =============================
Job ID: 12345678
Cluster: helix
User/Group: hd_ab123/hd_hd
State: COMPLETED (exit code 0)
Nodes: 2
Cores per node: 64
CPU Utilized: 3-04:11:46
CPU Efficiency: 97.90% of 3-05:49:52 core-walltime
Job Wall-clock time: 00:36:29
Memory Utilized: 432.74 GB (estimated maximum)
Memory Efficiency: 85.96% of 503.42 GB (251.71 GB/node)
Explanation:
- Nodes: Number of allocated nodes for the job.
- Cores per node: Number of physical cores per node allocated for the job.
- CPU Utilized: Sum of utilized core time.
- CPU Efficiency: 'CPU Utilized' with respect to core-walltime (= 'Nodes' x 'Cores per node' x 'Job Wall-clock time') in percent.
- Job Wall-clock time: runtime of the job.
- Memory Utilized: Sum of memory used. For multi node MPI jobs the sum is only correct when srun is used instead of mpirun.
- Memory Efficiency: 'Memory Utilized' with respect to total allocated memory for the job.
Job Monitoring Portal
For more detailed information about your jobs visit the job monitoring portal: https://helix-monitoring.bwservices.uni-heidelberg.de
Accounting
Jobs are billed for allocated CPU cores, memory and GPUs.
To see the accounting data of a specific job:
$ sacct -j <jobid> --format=user,jobid,account,nnodes,ncpus,time,elapsed,AllocTRES%50
To retrive the job history for a specific user for a certain time frame:
$ sacct -u <user> -S 2022-08-20 -E 2022-08-30 --format=user,jobid,account,nnodes,ncpus,time,elapsed,AllocTRES%50
Overview about free resources
On the login nodes the following command shows what resources are available for immediate use:
$ sinfo_t_idle