User Tools

Site Tools


srun

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
srun [2017/04/17 14:48]
root
srun [2021/03/01 11:14] (current)
root
Line 3: Line 3:
 Runs an executable file. It is really intended to be used from within **sbatch** scripts. Used within a script, each invocation of **srun** starts a new **job step** (terminology you will see in the slurm documentation).  Runs an executable file. It is really intended to be used from within **sbatch** scripts. Used within a script, each invocation of **srun** starts a new **job step** (terminology you will see in the slurm documentation). 
  
-Runs the job in the foreground (and blocks unless you use “&”).+Used from a terminal, srun runs the job in the foreground (and blocks unless you use “&”).
  
-If you use srun directly (in a login terminal) your job will end if you close your terminal, unless you redirect IO and **disown** the job. You can also use a "terminal multiplexer" line screen or byobu.+If you use srun directly (in a login terminal) your job will end if you close your terminal or close your laptop, unless you redirect IO and **disown** the job. You can also use a "terminal multiplexer" like screen, tmux, or byobu. However, even if you take steps to protect against "hang-ups", if the head node needs to be rebooted (to pick up kernel updates, for instance) that will terminate any jobs running through srun. A reboot of the head node will not affect jobs submitted using sbatch.
  
 ==== Examples ==== ==== Examples ====
  
 srun hostname srun hostname
- 
-srun -n3 hostname (runs 3 **tasks**: copies of the program specified, may run on the same node) 
- 
-srun -n20 hostname (runs 20 **tasks**, will run on multiple nodes) 
- 
-srun -N3 hostname (runs on 3 different nodes) 
  
 srun --pty bash -i  srun --pty bash -i 
Line 22: Line 16:
     * Will only run if there is a slot available on the node.     * Will only run if there is a slot available on the node.
  
 +srun -n3 hostname (runs 3 **tasks**: copies of the program specified, may run on the same node)
  
-==== Protecting against Hang-Ups ====+srun -n30 hostname (runs 30 **tasks**, will run on multiple nodes since no node in that standard queue has as many as 30 cores) 
 + 
 +srun -N3 hostname (runs on 3 different nodes) 
 + 
 + 
 +==== Protecting against "Hang-Ups====
  
 <code> <code>
Line 29: Line 29:
 disown disown
 </code> </code>
 +
 +But it's much better to use sbatch.
 +
  
srun.1492454893.txt.gz · Last modified: 2017/04/17 14:48 by root