Analysis
One of the core offerings of Flow is its ability to manage and run a suite of Nextflow pipelines. Here we will explore how those pipelines are represented, and how they are executed.
Pipelines
The pipeline model represents a single, distinct, named Nextflow pipeline. Different instances of Flow will have different pipelines installed. The key properties of pipelines are:
- Name
name
- Type
- string
- Description
The overall name for the pipeline, as it is presented to the user.
- Name
is_nfcore
- Type
- boolean
- Description
Whether or not this should be presented as an nf-core pipeline
- Name
is_demultiplex
- Type
- boolean
- Description
Whether or not the pipeline demultiplexes samples. When true, this tells Flow to perform additional steps when processing the pipeline outputs to ensure samples are created.
- Name
imports_samples
- Type
- boolean
- Description
Whether or not the pipeline imports samples. When true, this tells Flow to perform additional steps when processing the pipeline outputs to ensure samples are created.
There are two ways that pipelines are organised. The first is via via pipeline categories and pipeline subcategories. Each pipeline model has a many-to-one relationship with a pipeline subcategory model, which in turn has a many-to-one relationship with a pipeline category model. These determine how the pipelines are presented in the frontend, and each has a description of what the category/subcategory represents.
The second is with the pipeline repo model. Each pipeline must be assoicated with a git repo, with a distinct URL that Flow can pull from. Pipeline repos and categories/subcategories are orthogonal - multiple pipelines from a single repo can be in different categories, and the pipelines in a single category or subcategory can be from different repos.
Pipeline versions
A single pipeline will have one or more pipeline versions - these refer to specific commits in the repo, and contain the paths to the actual files that should be run. When you run a pipeline, you are running a specific pipeline version. The key properties of pipeline versions are:
- Name
name
- Type
- string
- Description
The name of the pipeline version as presented to the user.
- Name
git
- Type
- string
- Description
The git commit to use for this version - this can be a commit hash, a branch, or a tag.
- Name
private
- Type
- bool
- Description
If private, only admin users will be able to see and access this pipeline. Useful for testing pipeline integrations with Flow.
- Name
active
- Type
- bool
- Description
Only active pipeline versions can be run. Typically the most recent versions will be active, while older versions will be disabled by setting them to be inactive.
- Name
description
- Type
- string
- Description
A brief description of what the pipeline does (which may change in different versions).
- Name
long_description
- Type
- string
- Description
A more in-depth description of what the pipeline does (which also may change in different versions).
- Name
created
- Type
- int
- Description
The timestamp of the pipeline version's creation, which is used to order the versions.
- Name
path
- Type
- string
- Description
The path to the main pipeline .nf file (relative to the repo root). This is the file that should actually be run with
nextflow run
.
- Name
schema_path
- Type
- string
- Description
The path to the Flow schema file (relative to the repo root). This is a JSON file which describes the inputs and outputs of the pipeline.
- Name
config_paths
- Type
- string
- Description
A comma separated list of paths to any additional config files within the repo that should be applied when running. These are in addition to the global config files run for every pipeline.
- Name
copy_full
- Type
- bool
- Description
For some pipelines, there may be large, non-committed files in the repo that are needed for running. When this is true, the pipeline repo will be copied over for every run, instead of just being recreated from the
.git
directory.
- Name
upstream_pipeline_versions
- Type
- [ID]
- Description
For pipelines which can take fileset preparations as inputs, this defines the pipeline versions whose executions can be used.
Executions
When you run a pipeline, you create an execution object. This represents the running of a single pipeline version.
Flow uses Celery to manage the execution of pipelines. When a run is submitted, an execution object is created and a response returned to the user giving the ID of the new object. Meanwhile the job is added to the Celery queue. Once Celery selects the job, it will submit the Nextflow run in an install-specific way (different institutes will have different established systems for submitting such jobs) and then will watch the execution output to populate the database with new objects around what is created.
The key properties of executions are:
- Name
identifier
- Type
- string
- Description
The human readable name generated by Nextflow, typically two random words joined by an underscore.
- Name
pid
- Type
- string
- Description
The PID of the main Nextflow process on the server (the process executions will have their own PIDs).
- Name
dependent
- Type
- bool
- Description
Whether or not permissions applying to any samples or projects the execution is in should apply to this execution.
- Name
private
- Type
- bool
- Description
If
false
, anybody will be able to view the execution, even users not signed in (providing they can access the instance of Flow).
- Name
resequence_samples
- Type
- bool
- Description
Whether or not any samples created by the execution should be merged into existing samples where possible.
- Name
command
- Type
- string
- Description
The full command-line command that was used to run this execution.
- Name
params
- Type
- string
- Description
A JSON string containing the simple parameters passed to this execution.
- Name
data_params
- Type
- string
- Description
A JSON string containing the data IDs passed as parameters to this execution.
- Name
sample_params
- Type
- string
- Description
A JSON string containing the sample IDs passed as parameters to this execution, along with any additional columns of data.
- Name
nextflow_version
- Type
- string
- Description
The version of Nextflow this execution was run with.
- Name
stdout
- Type
- string
- Description
The full stdout produced by the run.
- Name
stderr
- Type
- string
- Description
The full stderr produced by the run.
- Name
exit_code
- Type
- int
- Description
The system exit code returned - 0 generally means it ran without issue.
- Name
status
- Type
- string
- Description
The Nextflow reported status of the execution.
- Name
created
- Type
- int
- Description
The timestamp for the initial creation of the execution in the request/response loop that submitted it.
- Name
task_started
- Type
- int
- Description
The timestamp for the start of the celery process that submitted the execution. This may be a few seconds after
created
or it may be many hours, depending on the Celery queue.
- Name
started
- Type
- int
- Description
The timestamp for the start of the Nextflow job itself - typically milliseconds after
task_started
.
- Name
finished
- Type
- int
- Description
The timestamp for the end of the Nextflow job.
- Name
task_finished
- Type
- int
- Description
The timestamp for the end of the celery process that submitted the execution. This may be some time after the Nextflow process itself ended, if there is a lot of post-processing to do.
- Name
owner
- Type
- ID
- Description
The user who owns the execution.
- Name
creator
- Type
- ID
- Description
The user who originally ran the execution.
- Name
group_owner
- Type
- ID
- Description
The group who owns the execution.
Process Executions
An execution will have zero or more process executions. Nextflow pipelines work by chaining together multiple processes which typically (and in Flow, always) run in their own containerised environment. The process execution model represents each of these for a given execution. The key attributes are:
- Name
name
- Type
- string
- Description
The full name of the process - typically the process name with some argument in parentheses at the end.
- Name
process_name
- Type
- string
- Description
The name of the process itself, without and distinguishing arguments.
- Name
identifier
- Type
- string
- Description
The Nextflow-generated identifier for the process.
- Name
started
- Type
- int
- Description
The timestamp for the start of the process execution.
- Name
finished
- Type
- int
- Description
The timestamp for the end of the process execution.
- Name
stdout
- Type
- string
- Description
The full stdout produced by the process execution.
- Name
stderr
- Type
- string
- Description
The full stderr produced by the process execution.
- Name
bash
- Type
- string
- Description
The bash script generated by Nextflow for this process execution.
- Name
exit_code
- Type
- int
- Description
The system exit code returned - 0 generally means it ran without issue.
- Name
status
- Type
- string
- Description
The Nextflow reported status of the process execution.