NAME

runjob - Run a job in the cluster using NBI::Slurm

VERSION

version 0.7.0

SYNOPSIS

runjob [options] "Command to run"

DESCRIPTION

The runjob script allows you to submit a job to the cluster using the NBI::Slurm module.

It provides a command-line interface for setting the job parameters, including the queue, memory, threads, and execution time.

OPTIONS

-n, --name STR

Specifies the name of the job (optional). If not provided, an automatic name will be generated based on the command being run.

-q, --queue STR

Specifies the queue name for the job. The default value is "nbi-short". Note that if you put a "*", it will be replaced by 'short', 'medium', or 'long' depending on the time specified with '--time'.

-m, --memory INT (Mb)

Specifies the amount of memory to use for the job. The default value is 8Gb. You can add a suffix like "900Mb" or "12Gb" (floats are not supported). An integer is interpreted as Mb if > 200, otherwise it is interpreted as Gb.

-c, --cores, --threads INT

Specifies the number of threads (cores) to use for the job. The default value is 1.

-T, --time STR

Specifies the time string for the job. The default value is "0d 8h". The format should be in the format of "Xd Xh Xm" where X represents the number of days (d), hours (h), and minutes (m) respectively.

--after INT

Specifies the job ID to wait for before running the job. This option can be used multiple times to specify multiple jobs to wait for.

-w, --tmpdir PATH

Specifies the temporary (working) directory for the job. The default value is "/tmp".

-r, --run

Runs the job immediately after submitting. If not specified, the script will only print the job script without running it.

--verbose

Enables verbose output, displaying additional information about the job and its options.

--help

Displays the help message for the script.

CONFIGURATION

The script will look for a configuration file in the user's home directory at ~/.nbislurm.config.

queue=qib-*,nbi-*
email=my@address
tmpdir=/home/user/slurm
memory=8000
time=3h

EXAMPLES

Submitting a job to the default queue with 4Gb memory and running the job:

runjob -m 4Gb -r "ls -l"

Submitting a job with a custom name, 2 threads, and running a Python script:

runjob -n "my-job" -c 2 -r "python script.py"

Chaining jobs together:

JOB1=$(runjob "echo 'Hello, world!'")
runjob --after $JOB1 "echo 'Goodbye, world!'"

AUTHOR

Andrea Telatin <proch@cpan.org>

COPYRIGHT AND LICENSE

This software is Copyright (c) 2023 by Andrea Telatin.

This is free software, licensed under:

The MIT (X11) License