Skip to main content

Python package for Domino.

Project description

Build amazing ideas, piece by piece.

Read the Docs


create workflow

Table of contents


About

Domino is an open source workflow management platform, with:

  • :desktop_computer: an intuitive Graphical User Interface that facilitates creating, editing and monitoring any type of Workflow, from data processing to machine learning
  • :package: a standard way of writing and publishing functional Pieces, which follows good practices for data modeling, documentation and distribution
  • :gear: a REST API that controls a running Apache Airflow instance

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:

  • :desktop_computer: create highly complex Workflows with simple point-and-click and drag-and-drop operations, in an user-friendly GUI
  • :package: make use of Pieces developed by other people, share and reuse your own Pieces
  • :busts_in_silhouette: collaborate in groups to edit and monitor Workflows
  • :chart_with_upwards_trend: experience a cleaner and more intuitive GUI for viewing Workflows results, including logs and richer reports with images and tables
  • :minidisc: shared storage for tasks in the same workflow
  • :arrows_counterclockwise: use gitSync to sync DAGs from files stored in a Git repository
  • :wheel_of_dharma: scalable, Kubernetes-native platform
  • :battery: powered by Apache Airflow for top-tier workflows scheduling and monitoring

Quick start

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.
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 install Domino in a Kubernetes cluster. For local testing, check out the instructions for running Domino in a local Kubernetes cluster with Kind.


GUI

The Domino frontend service is a React application that provides the GUI for easily creating, editing and monitoring Workflows. Here are some of its features:

Access authentication Sign up and login to use the Domino platform.

signup and login

Create Workspaces Create new Workspaces and add your github access token.

create workspace

Install Pieces repositories Install bundles of Pieces to your Domino Workspaces direclty from Github repositories, and use them in your Workflows.

install pieces

Create Workflows Create Workflows by dragging and dropping Pieces to the canvas, and connecting them.

create workflow

Edit Pieces 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.

edit pieces

Schedule Workflows Schedule Workflows to run periodically, at a specific date/time, or trigger them manually.

schedule workflows

Monitor Workflows Monitor Workflows in real time, including the status of each Piece, the logs and results of each run.

monitor workflow


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:

  • :snake: can execute anything written in Python, heavy-weight (e.g. Machine Learning) as well as light-weight (e.g. sending emails) tasks
  • :traffic_light: have well defined data models for inputs, outputs and secrets
  • :package: run in self-contained and isolated execution environments (Docker containers)
  • :gear: are immutable, guaranteeing reproducibility of your workflows
  • :octocat: are organized in git repositories, for easy packaging, distribution and installation
  • :bookmark_tabs: are properly versioned, tested and documented
  • :zap: are plug-and-play and versatile, can be easily incorporated in any workflow

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

  1. write your Python function as a Piece
  2. define the data types, dependencies, metadata and tests
  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.


REST

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

  • executing operations requested by the frontend service
  • interacting with the Airflow instance, including triggering, creating, editing and deleting Workflows (DAGs)
  • interacting with the Domino Database

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


Credits

Domino is developed and maintained by Tauffer Consulting.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

domino-py-0.5.5.tar.gz (64.0 kB view details)

Uploaded Source

Built Distribution

domino_py-0.5.5-py3-none-any.whl (78.7 kB view details)

Uploaded Python 3

File details

Details for the file domino-py-0.5.5.tar.gz.

File metadata

  • Download URL: domino-py-0.5.5.tar.gz
  • Upload date:
  • Size: 64.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.18

File hashes

Hashes for domino-py-0.5.5.tar.gz
Algorithm Hash digest
SHA256 216724f08f78a2cc91ae0fb69facec5e4ce5cfaf2305026ebf46719b15008c0f
MD5 422eb84096b4db140e4c0d888a963cc5
BLAKE2b-256 0464868324b44d03051804073ec714f21163cfe08679ace515fa2f17c7165a3d

See more details on using hashes here.

Provenance

File details

Details for the file domino_py-0.5.5-py3-none-any.whl.

File metadata

  • Download URL: domino_py-0.5.5-py3-none-any.whl
  • Upload date:
  • Size: 78.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.18

File hashes

Hashes for domino_py-0.5.5-py3-none-any.whl
Algorithm Hash digest
SHA256 5c10c450f1edf9f62400cd01bd3ef285a521d1a2666e515ede741c687207d888
MD5 14a3cff61ab9f85875d40e10ca076476
BLAKE2b-256 9542f6e4e1cf00ccb12a6ece8a4625a7c30c4a7dba00ab03ea5a0e201ea15cdd

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page