7 releases (breaking)

new 0.12.0 Jan 15, 2025
0.11.0 Jan 9, 2025
0.10.0 Jan 8, 2025
0.8.0 Nov 25, 2024
0.1.0 Dec 12, 2021

#88 in Web programming

Download history 1/week @ 2024-09-25 298/week @ 2024-10-16 19/week @ 2024-10-23 2/week @ 2024-10-30 108/week @ 2024-11-06 9/week @ 2024-11-13 127/week @ 2024-11-20 37/week @ 2024-11-27 16/week @ 2024-12-04 8/week @ 2024-12-11 318/week @ 2025-01-08

318 downloads per month

AGPL-3.0-only

1MB
20K SLoC

Obelisk

Deterministic workflow engine built on top of the WASM Component Model.

⚠️ This is a pre-release: Expect changes in the CLI, gRPC, WIT or database schema.

What's Included

  • Obelisk runtime: A single binary executing your deterministic workflows, activities and webhook endpoints, persisting each step in an event log using SQLite.
  • Control Interfaces: Access and manage your components and executions through:
    • CLI: Command-line interface using the obelisk executable.
    • gRPC API: Programmatic interaction.
    • Web UI: Visual and interactive interface, available at localhost:8080 by default.

How It Works

  • Schema-first design with end-to-end type safety: Uses the WASM Component Model and WIT IDL to generate API bindings between components.
  • Resilient Activities: Automatically retries on errors and timeouts, with input parameters and execution results persistently stored.
  • Replayable Workflows: Deterministic execution and a persisted event log make workflows replayable, enabling reliable recovery, debugging, and auditing of processes.

Use Cases

  • Periodic Tasks: Automate checks like customer limits, triggering activities such as transactional emails or project suspensions.
  • Background Job Processing: Offload and manage background tasks with built-in error handling and retries.
  • Mass Deployments: Manage large-scale deployments across systems efficiently.
  • End-to-End Testing: Automate tests with workflows, providing detailed logs for identifying and debugging issues (e.g., GraphQL API testing).
  • Webhook Integrations: Build webhook endpoints (e.g., GitHub) that trigger long-running workflows and interact with external APIs.

Concepts and features

  • Activities

    • Must be idempotent (retriable). This contract must be fulfilled by the activity itself.
    • WASI activities are executed in a WASM sandbox
      • Able to contact HTTP servers using the WASI 0.2 HTTP client.
    • Max execution duration support, after which the execution is suspended into temporary timeout.
    • Retries on errors - on WASM traps (panics), or when returning an Error result.
    • Retries on timeouts with exponential backoff.
    • Execution result is persisted.
  • Deterministic workflows

    • Replayable: Execution is persisted at every state change, so that it can be replayed after an interrupt or an error.
    • Running in a WASM sandbox, isolated from the environment
    • Automatically retried on failures like persistence errors, timeouts or even traps(panics).
    • Able to spawn child workflows or activities, either blocking until result arrives or awaiting the result asynchronously.
    • Join sets allow for structured concurrency, either blocking until child executions are done, or cancelling those that were not awaited (planned).
    • Distributed sagas (planned).
  • Webhook Endpoints

    • Mounted as a URL path, serving HTTP traffic.
    • Running in a WASM sandbox
    • Able to spawn child workflows or activities.
  • Work stealing executor

    • Periodically locking a batch of currently pending executions, starts/continues their execution
    • Cleaning up old hanging executions with expired locks. Executions that have the budget will be retried (planned).
    • Concurrency control - limit on the number of workers that can run simultaneously.

Installation

Supported platforms

  • Linux x64 - musl or glibc v2.35+
  • Mac OS 13 x64

Docker

CONTAINER_ID=$(docker run -d getobelisk/obelisk)
docker logs --follow $CONTAINER_ID | grep "Serving gRPC requests"
docker exec $CONTAINER_ID obelisk client component list
# See Usage for more details

Pre-built binary

Download latest release from the GitHub Release page.

Compiling from source

The compilation requires protoc Protocol Buffers compiler.

Using latest version from crates.io

Download using cargo-binstall

cargo binstall --locked obelisk

or build using cargo

cargo install --locked obelisk

Nix flakes

nix run github:obeli-sk/obelisk
# Install to the user's profile:
nix profile install github:obeli-sk/obelisk

Setting up the Garnix Cache is recommended to speed up the build.

Getting Started

Creating sample components from a template

See obelisk-templates

Configuration

See obelisk.toml for details.

Generating a sample configuration file

obelisk server generate-config

Starting the server

obelisk server run

Getting the list of loaded functions

obelisk client component list

Submitting a function to execute (either workflow or activity)

# Call fibonacci(10) activity from the workflow 500 times in series.
obelisk client execution submit testing:fibo-workflow/workflow.fiboa '[10, 500]' --follow

Contributing

This project has a roadmap and features are added in a certain order. If you would like to contribute a feature, please discuss the feature on GitHub. In order for us to accept patches and other contributions, you need to adopt our Contributor License Agreement (the "CLA"). The current version of the CLA can be found here.

Local development

Set up the development dependencies using nix flakes:

nix develop
# or `direnv allow`, after simlinking .envrc-example -> .envrc

Or manually download all dependencies, see dev-deps.txt and Ubuntu based verification Dockerfile Run the program

cargo run --release

Running Tests

./scripts/test.sh

Deterministic tests using the madsim simulator

./scripts/test-madsim.sh

Dependencies

~118MB
~2.5M SLoC