-
Notifications
You must be signed in to change notification settings - Fork 55
Architecture
This page describes high-level architecture of the REANA platform for version 0.8.x, 0.9.x.
Here you can find an overview diagram (and its drawio source) of the REANA architecture. It describes some common operations and components. This is a good starting point before diving into the codebase.
Researchers (Users) can interact with REANA platform via two different ways:
- reana-client, command line tool
- reana-ui, web app
Summary of core platform components:
- rest-api (reana-server), REST API server, processes and dispatches requests from users to internal REANA services;
- workflow scheduler, service responsible for scheduling workflows from different users based on scheduling rules;
- rest-api (reana-workflow-controller), internal REST API responsible for managing workflows (create, start workflows, etc.);
- reana-workflow-engine-xxxx, controls execution of a single workflow of some type like Yadage, CWL, Snakemake or Serial;
- reana-job-controller, works alongside workflow engine and dispatches workflow jobs to different clusters like Kubernetes, HTCondor or Slurm;
- reana-message-broker, RabbitMQ message broker used for distributing messages for workflows scheduling and progress updates;
- job-status-consumer, receives update messages from all running workflows via queue, updates database;
- SQL database (DB), depending on a setup, can be connected to REANA from outside, or hosted as part of REANA cluster.
Workflows are the basic units in REANA.
Each workflow has a name (e.g. myanalysis
), a run number (e.g. 42
),
and is identified with a unique UUID.
The workflow name is the same throughout the analysis lifetime, the run number is incremented every time the workflow is run, and the UUID is generated each time anew.
It is also possible to restart workflows. In this case, the workflow run number is followed by a dot, followed by a restart number.
The workflow run during its execution may take up different statuses, from its creation to its conclusion. Below you can find a table of workflow statuses and their corresponding values in the database:
Status name | Value in database |
---|---|
created | 0 |
running | 1 |
finished | 2 |
failed | 3 |
deleted | 4 |
stopped | 5 |
queued | 6 |
pending | 7 |
Throughout the workflow lifetime it will transition from one status to another. Here is the diagram (and its drawio source) of possible transitions between different workflow statuses:
REANA reproducible analysis platform
blog.reana.io | docs.reana.io | forum.reana.io | www.reana.io |
@gitter | @mattermost | @twitter
Introduction
Getting started
- Setting up your system
- Cloning sources
- Using production-like development mode
- Using live-code-reload and debug mode
Issue lifecycle
Understanding code base
Technology tips and tricks
- Tips for Docker
- Tips for Git
- Tips for GitLab
- Tips for Keycloak
- Tips for Kind
- Tips for Kubernetes
- Tips for OpenAPI
- Tips for PostgreSQL
- Tips for Python
- Tips for RabbitMQ
- Tips for SQLAlchemy