NAME
NBI::Job - A class for representing a job for NBI::Slurm
VERSION
version 0.4.3
SYNOPSIS
use NBI::Job;
my $job = NBI::Job->new(
-name => "job-name",
-command => "ls -l",
);
Multiple commands can be encoded as a list:
my $job = NBI::Job->new(
-name => "job-name",
-commands => ["ls -l", "echo done"]
);
DESCRIPTION
The NBI::Job
module provides a class for representing a job to be submitted to SLURM for High-Performance Computing (HPC). It allows you to define the name of the job, the commands to be executed, and various options related to the job.
METHODS
new()
Create a new instance of NBI::Job
. Note that the options must be made as NBI::Opts
class.
my $job = NBI::Job->new(
-name => "job-name",
-command => "ls -l",
-opts => $options
);
# Multi commands my $job = NBI::Job->new( -name => "job-name", -commands => ["ls -l", "echo done"] );
This method creates a new CNBI::Job object with the specified parameters. The following parameters are supported:
-name (string, optional): The name of the job. If not provided, a default name will be assigned.
-command (string, optional): The command to be executed by the job. Only one command can be specified using this parameter.
-commands (arrayref, optional): An array reference containing multiple commands to be executed by the job. If both
-command
and-commands
are provided, the-command
will be appended to the-commands
array.-opts (
NBI::Opts
object, optional): An instance of theNBI::Opts
class representing the options for the job. If not provided, a default instance with the "nbi-short" queue will be used.
name
Accessor method for the job name.
$job->name = "new-name";
my $name = $job->name;
This method allows you to get or set the name of the job. If called with an argument, it sets the name of the job to the specified value. If called without an argument, it returns the current name of the job.
jobid
Accessor method for the job ID.
$job->jobid = 12345;
my $jobid = $job->jobid;
This method allows you to get or set the ID of the job. If called with an argument, it sets the ID of the job to the specified value. If called without an argument, it returns the current ID of the job. It's currently a public method but it's meant to be updated by the module itself.
outputfile
Accessor method for the output file path, where the output of the job will be written. Add %j
in the name to use the JobID.
$job->outputfile = "/path/to/output.txt";
my $outputfile = $job->outputfile;
This method allows you to get or set the path of the output file generated by the job. If called with an argument, it sets the output file path to the specified value. If called without an argument, it returns the current output file path.
errorfile
Accessor method for the error file path.
$job->errorfile = "/path/to/error.txt";
my $errorfile = $job->errorfile;
This method allows you to get or set the path of the error file generated by the job. If called with an argument, it sets the error file path to the specified value. If called without an argument, it returns the current error file path.
append_command
Append a command to the job.
$job->append_command("echo done");
This method allows you to append a command to the list of commands executed by the job.
prepend_command
Prepend a command to the job.
$job->prepend_command("echo start");
This method allows you to prepend a command to the list of commands executed by the job.
commands
Get the list of commands for the job.
my $commands = $job->commands;
This method returns an array reference containing the commands to be executed by the job.
commands_count
Get the number of commands for the job.
my $count = $job->commands_count;
This method returns the number of commands defined for the job.
set_opts
Set the options for the job.
$job->set_opts($opts);
This method allows you to set the options for the job using an instance of the NBI::Opts
class.
get_opts
Get the options for the job.
my $opts = $job->get_opts;
This method returns the options for the job as an instance of the CNBI::Opts class.
opts
Accessor method for the options of the job.
my $opts = $job->opts;
This method returns the options for the job as an instance of the CNBI::Opts class.
script
Generate the sbatch script for the job.
my $script = $job->script;
This method generates the sbatch script for the job based on the current settings and returns it as a string.
run
Submit the job to SLURM.
my $jobid = $job->run;
This method submits the job to SLURM for execution. It generates the sbatch script, writes it to a file, and uses the "sbatch" command to submit the job. If the submission is successful, it returns the job ID assigned by SLURM. Otherwise, it throws an exception.
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