Wiki Page Content

Differences between revisions 7 and 18 (spanning 11 versions)
Revision 7 as of 2020-04-14 13:15:20
Size: 5896
Editor: fhoma
Comment:
Revision 18 as of 2020-09-22 04:32:53
Size: 8101
Editor: fhoma
Comment: Adding --mem
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
<<TableOfContents(1)>>
------
<<Anchor(top|scroll to the top of the page)>>
Line 5: Line 3:
---- <<TableOfContents(2)>>
Line 9: Line 7:
Do not hesitate to ask for some help wen needed. Do not hesitate to ask for some help when needed.
Line 22: Line 20:
The '''normal''' partition is the default partition if you submit a job without precising witch partition should be used you job will be placed in one of the normal partition. The '''normal''' partition is the default partition if you submit a job without precising which partition should be used. Your job will be placed in the normal partition (250GB).
Line 26: Line 24:
Use ''-p'' option can be used to specify the needed partition. Use ''-p'' to specify needed partition.
Line 30: Line 28:
By default only some software will be available when login. To be able use other software scripts you should first load then. By default only some software will be available at login. To be able to use other software scripts you should first load them.
Line 32: Line 30:
The command '''module''' will help you to manage the modules dependencies. The command '''module''' will help you to manage modules and their dependencies.
Line 34: Line 32:
To to check which software are installed, can be used after importing, To check which programs are loaded (ready to be used), use the command below.
Line 45: Line 43:
to check which software are available, ready to be used without importing anything. To check which programs are available (can be loaded).
Line 92: Line 90:
Loading a module can be done following those 3 steps,
 1. Locate the module, module avail
 2. Check how to load it, module spider <<MODULENAME/VERSION>>
 3. Load you module using the instructions from step 2
Loading a module can be done following these 3 steps,
 1. Locate the module, '''module avail'''
 2. Check how to load it, '''module spider <<MODULENAME/VERSION>>'''
 3. Load your module using the instructions '''module load <<MODULENAME/VERSION>>'''
 4. Check that the module is loaded, '''module list'''
 5. Enjoy!!! ;-)
Line 108: Line 108:
#SBATCH -p normal # Partition to use, another possible value is bigmem
#SBATCH -N 1 # Total number of nodes requested
#SBATCH -n 16 # Total number of mpi tasks requested
#SBATCH -t 01:30:00 # Run time ([d-]hh:mm:ss) - 1.5 hours
#SBATCH -e /work/<<UID>>/job.%j.err # Name of stderr output file (%j expands to jobId)
#SBATCH -n 16 # Total number of cpu requested or total number of mpi tasks
#SBATCH --mem=2000 # Maximum amount of memory in Mb the job can use
#SBATCH -t 00:30:00 # Run time ([d-]hh:mm:ss) - 1.5 hours
#SBATCH --mail-type=ALL
#SBATCH --mail-user=your.email@wur.nl
Line 124: Line 126:

Here are some explanation for obscure elements,

 Line starting with #SBATCH:: Those lines are option given to sbatch. They are different from the command you are running.

 We use %j in the -o option:: This is a place holder, it will be replaced by the job id of your run. The use of that makes it easier to find out which standard output correspond to which task. It could be removed but make sure that all the tasks have a specific output file.

 -N 1:: Given the limited number of nodes, all users are invited to only use 1 node. Most bioinfo software can not be run on more than 1 node so don't waste resources.

 -t option:: This sets a limit of time for your task to run. If ''00:05:00'', your job will run for 5 minutes. What if it is not finished? You will have to rerun it again giving a higher time. If the command you are running has the ability to continue from a checkpoint, you can use that ability to reduce the running time. This parameter is difficult to estimate in most cases, do not hesitate to over estimate at the beginning.
Line 146: Line 158:
#SBATCH -p normal # Partition to use, another possible value is bigmem
#SBATCH -N 1 # Total number of nodes requested
#SBATCH -n 16 # Total number of mpi tasks requested
#SBATCH -e /work/test/job.%j.err # Name of stderr output file (%j expands to jobId)
#SBATCH -n 16 # Total number of cpu or total number of mpi tasks
#SBATCH --mem=2000 # Maximum amount of memory in Mb the job can use, 2000 is 2Gb
Line 154: Line 166:
#Work directory # Defining variable for work directory
Line 156: Line 168:
# Defining variable for temporary directory
# We do this because our command uses tmp folder
Line 157: Line 171:
# Defining variable for output directory
Line 158: Line 173:
# Defining variable for forward and reverse read file
Line 161: Line 177:
#Creating necessary folder
mkdir $output_dir $tmp_dir
# Creating temporary folder
# Megahit will complain if "output" folder already exists
mk
dir $tmp_dir
Line 164: Line 181:
# Running my command
megahit -1 $f_read -2 $r_read --tmp-dir $tmp_dir --out-prefix $output_dir/r3
# Command to run
# We use previously defined varibales to set the values of megahit options

megahit -1 $f_read -2 $r_read --tmp-dir $tmp_dir --out-dir $output_dir --out-prefix r3
Line 167: Line 185:


{{{#!wiki caution
'''YOUR ATTENTION PLEASE!'''
Once your job is submitted, ''slurm'' takes care of it until it is done. There is no need to run your job in ''screen'' or any special terminal.
}}}

||<tablestyle="width: 99%;" style="border: none; font-weight: bold; font-size: 20px;"> <<[[transfering data]] ||<style="text-align: center; width: 33%; border: none; font-weight: bold; font-size: 20px;"> ^[[#top]] ||<style="border: none; width: 33%; text-align: right; font-weight: bold; font-size: 20px;"> [[Monitor jobs]]>> ||

Submitting jobs

Whatever you read here may need to be adjusted to fit your specific case.

Do not hesitate to ask for some help when needed.

Filesystems

Some but not all partitions are available to the compute nodes. Compute nodes will not be able to access any data from filesystems that are not listed here. /work /scratch /home/

Slurm partitions

There are currently 2 partitions, normal and bigmem.

The normal partition is the default partition if you submit a job without precising which partition should be used. Your job will be placed in the normal partition (250GB).

The normal partition has limited RAM of 250GB, in case you need more than that please use the bigmem partition.

Use -p to specify needed partition.

Load necessary software

By default only some software will be available at login. To be able to use other software scripts you should first load them.

The command module will help you to manage modules and their dependencies.

To check which programs are loaded (ready to be used), use the command below.

module list

Expected output is,

Currently Loaded Modules:
  1) autotools   2) prun/1.3   3) gnu8/8.3.0   4) openmpi3/3.1.4   5) ohpc

To check which programs are available (can be loaded). The same command can be used to search a specific package.

module avail

Expected output is,

--------------------------------------------------- /opt/ohpc/pub/moduledeps/gnu8-openmpi3 ----------------------------------------------------
   adios/1.13.1     hypre/2.18.1    netcdf-cxx/4.3.1        petsc/3.12.0        py2-scipy/1.2.1     scorep/6.0            trilinos/12.14.1
   boost/1.71.0     imb/2018.1      netcdf-fortran/4.5.2    phdf5/1.10.5        py3-mpi4py/3.0.1    sionlib/1.7.4
   dimemas/5.4.1    mfem/4.0        netcdf/4.7.1            pnetcdf/1.12.0      py3-scipy/1.2.1     slepc/3.12.0
   extrae/3.7.0     mpiP/3.4.1      omb/5.6.2               ptscotch/6.0.6      scalapack/2.0.2     superlu_dist/6.1.1
   fftw/3.3.8       mumps/5.2.1     opencoarrays/2.8.0      py2-mpi4py/3.0.2    scalasca/2.5        tau/2.28

-------------------------------------------------------- /opt/ohpc/pub/moduledeps/gnu8 --------------------------------------------------------
   hdf5/1.10.5     metis/5.1.0    mvapich2/2.3.2    openblas/0.3.7        pdtoolkit/3.25      py3-numpy/1.15.3
   likwid/4.3.4    mpich/3.3.1    ocr/1.0.1         openmpi3/3.1.4 (L)    py2-numpy/1.15.3    superlu/5.2.1

------------------------------------------------------------- /tools/modulefiles --------------------------------------------------------------
   MEGAHIT/1.2.9

---------------------------------------------------------- /opt/ohpc/pub/modulefiles ----------------------------------------------------------
   EasyBuild/3.9.4          clustershell/1.8.2    gnu7/7.3.0         llvm5/5.0.1        pmix/2.2.2               valgrind/3.15.0
   autotools         (L)    cmake/3.15.4          gnu8/8.3.0  (L)    ohpc        (L)    prun/1.3          (L)
   charliecloud/0.11        gnu/5.4.0             hwloc/2.1.0        papi/5.7.0         singularity/3.4.1

  Where:
   L:  Module is loaded

Use "module spider" to find all possible modules.
Use "module keyword key1 key2 ..." to search for all possible modules matching any of the "keys".

To search for a module,

module avail <<keyword>>
#OR
module spider <<keyword>>

To load a module do,

module load <<MODULENAME/VERSION>>

Loading a module can be done following these 3 steps,

  1. Locate the module, module avail

  2. Check how to load it, module spider <<MODULENAME/VERSION>>

  3. Load your module using the instructions module load <<MODULENAME/VERSION>>

  4. Check that the module is loaded, module list

  5. Enjoy!!! ;-)

Read more about module usage https://lmod.readthedocs.io/en/latest/010_user.html

Prototype of batch script

This prototype should be in a script file, for example, my_first_script.sbatch

   1 #!/bin/bash
   2 
   3 #SBATCH -J test               # Job name
   4 #SBATCH -o /work/<<UID>>/job.%j.out   # Name of stdout output file (%j expands to jobId)
   5 #SBATCH -e /work/<<UID>>/job.%j.err   # Name of stderr output file (%j expands to jobId)
   6 #SBATCH -n 16                 # Total number of cpu requested or total number of mpi tasks
   7 #SBATCH --mem=2000            # Maximum amount of memory in Mb the job can use
   8 #SBATCH -t 00:30:00           # Run time ([d-]hh:mm:ss) - 1.5 hours
   9 #SBATCH --mail-type=ALL
  10 #SBATCH --mail-user=your.email@wur.nl
  11 
  12 # Load your software/command
  13 module load CMD/version
  14 
  15 # Run your command
  16 CMD [OPTIONS] ARGUMENTS

To run a sbatch script use

sbatch <<script name>>

Here are some explanation for obscure elements,

Line starting with #SBATCH
Those lines are option given to sbatch. They are different from the command you are running.
We use %j in the -o option
This is a place holder, it will be replaced by the job id of your run. The use of that makes it easier to find out which standard output correspond to which task. It could be removed but make sure that all the tasks have a specific output file.
-N 1
Given the limited number of nodes, all users are invited to only use 1 node. Most bioinfo software can not be run on more than 1 node so don't waste resources.
-t option

This sets a limit of time for your task to run. If 00:05:00, your job will run for 5 minutes. What if it is not finished? You will have to rerun it again giving a higher time. If the command you are running has the ability to continue from a checkpoint, you can use that ability to reduce the running time. This parameter is difficult to estimate in most cases, do not hesitate to over estimate at the beginning.

Example of sbtach script

Let's assume a few things here,

  1. You need to be logged in
  2. Your data is available
  3. The needed software is available
  4. The test will be run in folder /work/test/

Preparing for the run,

   1 mkdir /work/test/

Let's try to run an assembly using megahit,

   1 #!/bin/bash
   2 
   3 #SBATCH -J test               # Job name
   4 #SBATCH -o /work/test/job.%j.out   # Name of stdout output file (%j expands to jobId)
   5 #SBATCH -e /work/test/job.%j.err   # Name of stderr output file (%j expands to jobId)
   6 #SBATCH -n 16                 # Total number of cpu or total number of mpi tasks
   7 #SBATCH --mem=2000            # Maximum amount of memory in Mb the job can use, 2000 is 2Gb
   8 #SBATCH -t 01:30:00           # Run time ([d-]hh:mm:ss) - 1.5 hours
   9 
  10 # Load your available meghit
  11 module load MEGAHIT/1.2.9
  12 
  13 # Defining variable for work directory
  14 based=/work/test
  15 # Defining variable for temporary directory
  16 # We do this because our command uses tmp folder
  17 tmp_dir=$based/tmp
  18 # Defining variable for output directory
  19 output_dir=$based/output
  20 # Defining variable for forward and reverse read file
  21 f_read=/tools/test_data/assembly/r3_1.fa.gz
  22 r_read=/tools/test_data/assembly/r3_2.fa.gz
  23 
  24 # Creating temporary folder
  25 # Megahit will complain if "output" folder already exists
  26 mkdir $tmp_dir
  27 
  28 # Command to run
  29 # We use previously defined varibales to set the values of megahit options
  30 megahit -1 $f_read -2 $r_read --tmp-dir $tmp_dir --out-dir $output_dir --out-prefix r3

YOUR ATTENTION PLEASE! Once your job is submitted, slurm takes care of it until it is done. There is no need to run your job in screen or any special terminal.

<<transfering data

^#top

Monitor jobs>>

Submitting jobs (last edited 2024-02-23 15:49:56 by fhoma)