Home

Awesome

<p align="center"> <img src="media/brand/main_logo.png" width="450" title="Domino"> </p> <p align="center"><i>Build amazing ideas, piece by piece.</i></p> <p align="center"> <a href="https://tauffer-consulting.github.io/domino-docs/docs/intro"> <img alt="Docs" src="https://img.shields.io/badge/Documentation-docs?logo=readthedocs&logoColor=white&labelColor=gray&color=%231e4c94"> </a> <a href="https://pypi.org/project/domino-py"> <img src="https://img.shields.io/pypi/v/domino-py?color=%231BA331&label=PyPI&logo=python&logoColor=%23F7F991%20"> </a> <a href="https://artifacthub.io/packages/helm/domino/domino"> <img src="https://img.shields.io/endpoint?url=https://artifacthub.io/badge/repository/domino"> </a> <a href="https://codecov.io/gh/Tauffer-Consulting/domino" > <img src="https://codecov.io/gh/Tauffer-Consulting/domino/graph/badge.svg?token=WTJPH7FSNJ"/> </a> <a href="https://doi.org/10.5281/zenodo.10214754"> <img src="https://zenodo.org/badge/DOI/10.5281/zenodo.10214754.svg" alt="DOI"> </a> <a href="https://github.com/sponsors/Tauffer-Consulting"> <img src="https://img.shields.io/static/v1?label=Sponsor&message=%E2%9D%A4&logo=GitHub&color=%23fe8e86"> </a> </p> <br>

create-workflow

Table of contents

<br>

About

Domino is an open source workflow management platform, with:

Creating Workflows in the GUI is as simple as dragging and dropping Pieces to the canvas, and connecting them. The user can schedule the Workflow to run periodically, at a specific date/time, or trigger it manually. The monitoring page shows the status of each Workflow Piece in real time, including the logs and results of each run.

Pieces are functional units that can be reused in multiple Workflows. Pieces can execute anything that can be written in Python, and can be easily distributed and installed directly from Github repositories to be used in Domino Workflows.

Every Domino Workflow corresponds to an Apache Airflow DAG, and each Piece corresponds to an Airflow task. Domino controls an Airflow instance, which is responsible for executing, scheduling and monitoring the Workflows (DAGs).

You can think of Domino as Airflow with superpowers:

<br>

Quick start

Check out the quick start guide in the documentation.

The Domino Python package can be installed via pip. We reccommend you install Domino in a separate Python environment.

pip install domino-py[cli]

You can then use Domino command line interface to easily run the Domino platform locally (requires Docker Compose V2). Go to a new, empty directory and run the following command:

domino platform run-compose

After all processes started successfully, navigate to localhost:3000 to access the Domino frontend service. <br> Obs.: the first time you run the platform, it may take a few minutes to download the Docker images.

Running the Domino platform locally with Docker compose is useful for development and testing purposes. For production environments, we recommend you deploy Domino and Airflow to a Kubernetes cluster. For other deployment modes, check out the instructions in the documentation.

<br>

GUI

The Domino frontend service is a React application that provides the GUI for easily creating, editing and monitoring Workflows. Check out the GUI documentation for more details.

<details> <summary> <strong>Access authentication</strong> </summary> Sign up and login to use the Domino platform. <br></br>

signup and login

</details> <details> <summary> <strong>Select or Create Workspaces</strong> </summary> Select an existing or create a new Workspace. <br></br>

create workspace

</details> <details> <summary> <strong>Install Pieces repositories</strong> </summary> Install bundles of Pieces to your Domino Workspaces direclty from Github repositories, and use them in your Workflows. <br></br>

install pieces

</details> <details> <summary> <strong>Create Workflows</strong> </summary> Create Workflows by dragging and dropping Pieces to the canvas, and connecting them. <br></br>

create-workflow

</details> <details> <summary> <strong>Edit Pieces</strong> </summary> Edit Pieces by changing their input. Outputs from upstream Pieces are automatically available as inputs for downstream Pieces. Pieces can pass forward any type of data, from simple strings to heavy files, all automatically handled by Domino shared storage system. <br></br>

edit pieces

</details> <details> <summary> <strong>Configure Workflows</strong> </summary> Configure and schedule Workflows to run periodically, at a specific date/time, or trigger them manually. <br></br>

schedule workflows

</details> <details> <summary> <strong>Monitor Workflows</strong> </summary> Monitor Workflows in real time, including the status of each Piece, the logs and results of each run. <br></br>

run-pieces7

</details> <br>

Pieces

Pieces

Pieces are the secret sauce of Domino, they are functional units that can be distributed and reused in multiple Workflows. Domino Pieces are special because they:

It is very easy to create and share your own Pieces:

  1. write your Python function as a Piece <br>
  2. define the data types, dependencies, metadata and tests <br>
  3. publish in a git repository (public or private)

The Pieces repository template provides the basic structure, example files and automatic actions for a seamless Pieces creation experience.

Read more in the Pieces documentation.

<br>

REST

The Backend service is a REST API that controls a running Apache Airflow instance. It is responsible for:

The REST service is written in Python, using the FastAPI framework. Read more about it in the REST documentation.

<br>

Credits

Domino is developed and maintained by Tauffer Consulting.