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.1.tar.gz (83.9 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.1-py3-none-any.whl (73.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: arrakis_server-0.9.1.tar.gz
  • Upload date:
  • Size: 83.9 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.1.tar.gz
Algorithm Hash digest
SHA256 8fc9ae55c7688edcca04a500b0a794aabdecd818e3e308362384d361dfcb7bb8
MD5 005de9b8157d998cfde5bef1ceac8c53
BLAKE2b-256 7f9e99b525fd439c60a03a12e9534afd6d0e99614daedad799f83baf93da22e1

See more details on using hashes here.

File details

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

File metadata

  • Download URL: arrakis_server-0.9.1-py3-none-any.whl
  • Upload date:
  • Size: 73.5 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 83b7955bd4308c47308800b2cc791428148ab9c0e5d0b6af3bfdfbf049531f5e
MD5 4152b45cf54b0e3e2b4554a7b240272d
BLAKE2b-256 6a7c9129d868964e9e764a044858b2f4479a0f0c510cfa2672a37b4d220f4a54

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