Skip to content

Run workflows with various latency optimizations and view execution latency statistics

Notifications You must be signed in to change notification settings

temporal-sa/temporal-latency-optimization-scenarios

Repository files navigation

Temporal Latency Optimization Scenarios

This repository contains a set of scenarios to test the latency of Temporal workflows in various configurations.

Results screen for the Update-With-Start (Local Activities) scenario: Latency Result UI

Scenarios

  • Run Workflow (Regular Activities): Runs the workflow in its entirety and returns the result to the client.
  • Run Workflow (Regular Activities): Runs the workflow in its entirety but uses local activities and returns the result to the client.
  • Update-With-Start (Regular Activities): Demonstrates the "Early Return" pattern. Returns a value to the client from an update before the workflow completes.
  • Update-With-Start (Local Activities): Demonstrates the "Early Return" pattern. Same as Update-With-Start (Regular Activities), but uses a local activity inside the update handler.
  • Eager Workflow Start: runs the workflow in its entirety eagerly with local activities and returns the result to the client.

Setup

  1. Ensure you have a Temporal Service running. You can use the Temporal Cloud or run a local instance (brew install temporal && temporal server start-dev).
  2. Install the just CLI tool: brew install just.
  3. Clone this repository and navigate to the root directory: git clone https://github.com/temporal-sa/temporal-latency-optimization-scenarios.git and cd temporal-latency-optimization-scenarios.
  4. Install the dependencies for the web server and the Python worker: cd web && npm install && cd ../worker && poetry install.
  5. Copy the .env.template file to .env and update the values as needed.

Enable Pre-Release Features

  1. You may need to enable Eager Workflow Start

  2. For Cloud, reach out to your account team

  3. For local testing, add this to your temporal server start-dev:

    --dynamic-config-value system.enableEagerWorkflowStart=true

Running the Scenarios

Before running any just commands, ensure your environment is clean by unsetting any existing Temporal environment variables:

unset TEMPORAL_TASK_QUEUE TEMPORAL_CONNECTION_NAMESPACE TEMPORAL_CONNECTION_TARGET TEMPORAL_CONNECTION_MTLS_KEY_FILE TEMPORAL_CONNECTION_MTLS_CERT_CHAIN_FILE TEMPORAL_CONNECTION_WEB_PORT CALLER_API_PORT PUBLIC_WEB_URL
  1. Start the web server: just run_web.
  2. Start the Temporal worker: just run_temporal.
  3. Navigate to the web server in your browser (default is http://0.0.0.0:5178).

Go Workflows

The above workflows are implemented in Java. Go implementations are included for your benefit, see the golang samples readme. In testing Go was about 8% faster than Java.

This was with about 30 ms of latency from a remote lab to AWS us-east-1, so with lower latency Go's faster speed would be more pronounced.

About

Run workflows with various latency optimizations and view execution latency statistics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published