Skip to main content

Server implementation of the Arrakis low-latency timeseries data distribution platform

Project description

arrakis-server

Arrakis server

ci ci documentation pypi version


Server implementation of the Arrakis low-latency timeseries data distribution platform. Serve historical and live detector data to clients over Apache Arrow Flight, either from a backend you provide or by acting as an information server that routes requests to other Arrakis endpoints.

Resources

Installation

With pip:

pip install arrakis-server

With Docker:

docker run --net=host -it containers.ligo.org/ngdd/arrakis-server:latest

Where to Start

  • Tutorial — New to arrakis-server? Run a mock server and connect a client step by step.
  • User Guide — Running the server, configuring backends, scope maps, multi-backend deployments, and production tips.
  • Background — How the server works: Flight dispatch, the backend trait, retention-based routing, and the metadata model.
  • API Reference — Auto-generated documentation from source code.

Features

  • Pluggable backends via Python entry points
  • Built-in mock backend for local testing and CI
  • Information-server mode that routes requests across multiple endpoints
  • Retention-aware request routing, splitting time ranges across live and historical backends
  • Time-valued channel metadata for evolving detector configurations
  • Publish and partition endpoints for Kafka-backed publishing backends

Quickstart

Run a mock server

The mock backend generates synthetic timeseries for a predefined set of H1 and L1 channels:

arrakis-server mock

Then connect with the Arrakis client CLI:

arrakis find "H1:.*"

Serve custom mock channels

Pass one or more TOML files defining your own channels:

arrakis-server mock my_channels.toml

A minimal channel file:

["common"]
publisher = "MY_PUBLISHER"
sample_rate = 256
data_type = "float32"
stride = 62_500_000
max_latency = 1_000_000_000

["MY:CHANNEL-NAME"]
func = "3*t + cos(t)"

func accepts any SymPy expression in t (GPS seconds) to generate deterministic waveforms.

Run as an information server

An information server holds no data of its own; it routes client requests to other Arrakis endpoints based on a scope map:

arrakis-server --scope-map scope.yaml

The scope map lists each downstream endpoint along with the scopes and retention windows it serves. See the Scope Maps guide for the file format, and Multi-Backend Deployments for composing live and historical backends.

Write a backend

Backends plug in via the arrakis-server-backend entry-point group. A minimal backend implements the ServerBackend protocol and registers in its package's pyproject.toml:

[project.entry-points.arrakis-server-backend]
mybackend = "my_package.backend:MyBackend"

See Writing a Backend for the full interface and a complete example.

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

arrakis_server-0.9.0.tar.gz (82.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

arrakis_server-0.9.0-py3-none-any.whl (72.6 kB view details)

Uploaded Python 3

File details

Details for the file arrakis_server-0.9.0.tar.gz.

File metadata

  • Download URL: arrakis_server-0.9.0.tar.gz
  • Upload date:
  • Size: 82.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.5 cpython/3.13.12 HTTPX/0.28.1

File hashes

Hashes for arrakis_server-0.9.0.tar.gz
Algorithm Hash digest
SHA256 c45db3e596121317fc0a879e5cf39cd4fe0bb01d74c5c58300e57d3a8861ad79
MD5 36719250ad2d5c1c4aa56620f7f42150
BLAKE2b-256 86853bdbdae19ed1968f5e45cead1dad8aac6215027380a7cffa9cf17dc1ccf2

See more details on using hashes here.

File details

Details for the file arrakis_server-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: arrakis_server-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 72.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.5 cpython/3.13.12 HTTPX/0.28.1

File hashes

Hashes for arrakis_server-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 bb32365720ff854dedba0edf380e7b5350335bee29c0a9d3202c2e295ce108ce
MD5 0b0624a3e434267160b95ee3fc97fd19
BLAKE2b-256 045940a618fef0972719fd3ddb9106c68e30038c743c8fc348ea0f5b6bec5078

See more details on using hashes here.

Supported by

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