Skip to main content

Python client library for the Arrakis low-latency timeseries data distribution platform

Project description

arrakis-python

Arrakis Python client library

ci ci documentation pypi version conda version


Python client library for the Arrakis low-latency timeseries data distribution platform. Query, stream, and publish timeseries data.

Resources

Installation

With pip:

pip install arrakis

With conda:

conda install -c conda-forge arrakis-python

Where to Start

  • Tutorial — New to arrakis? Fetch your first timeseries data step by step.
  • User Guide — Fetching, streaming, channel discovery, publishing, the CLI, and more.
  • Background — How the system works: Arrow Flight, Kafka, multiplexing, and the data model.
  • API Reference — Auto-generated documentation from source code.

Features

  • Stream live and historical timeseries data
  • Describe channel metadata
  • Search for channels matching a set of conditions
  • Publish timeseries data
  • Command-line interface for all operations

Quickstart

Fetch timeseries

import arrakis

start = 1187000000
end = 1187001000
channels = [
    "H1:CAL-DELTAL_EXTERNAL_DQ",
    "H1:LSC-POP_A_LF_OUT_DQ",
]

block = arrakis.fetch(channels, start, end)
for channel, series in block.items():
    print(channel, series)

where block is a [arrakis.block.SeriesBlock][] and series is a [arrakis.block.Series][].

Stream timeseries

1. Live data
import arrakis

channels = [
    "H1:CAL-DELTAL_EXTERNAL_DQ",
    "H1:LSC-POP_A_LF_OUT_DQ",
]

for block in arrakis.stream(channels):
	print(block)
2. Historical data
import arrakis

start = 1187000000
end = 1187001000
channels = [
    "H1:CAL-DELTAL_EXTERNAL_DQ",
    "H1:LSC-POP_A_LF_OUT_DQ",
]

for block in arrakis.stream(channels, start, end):
    print(block)

Describe metadata

import arrakis

channels = [
    "H1:CAL-DELTAL_EXTERNAL_DQ",
    "H1:LSC-POP_A_LF_OUT_DQ",
]

metadata = arrakis.describe(channels)

where metadata is a dictionary mapping channel names to [arrakis.channel.Channel][].

Find channels

import arrakis

for channel in arrakis.find("H1:LSC-*"):
    print(channel)

where channel is a [arrakis.channel.Channel][].

Count channels

import arrakis

count = arrakis.count("H1:LSC-*")

Publish timeseries

from arrakis import Channel, Publisher, SeriesBlock, Time
import numpy

# admin-assigned ID
publisher_id = "my_producer"

# define channel metadata
metadata = {
    "H1:FKE-TEST_CHANNEL1": Channel(
        "H1:FKE-TEST_CHANNEL1",
        data_type=numpy.float64,
        sample_rate=64,
    ),
    "H1:FKE-TEST_CHANNEL2": Channel(
        "H1:FKE-TEST_CHANNEL2",
        data_type=numpy.int32,
        sample_rate=32,
    ),
}

publisher = Publisher(publisher_id)
publisher.register()

with publisher:
    # create block to publish
    series = {
        "H1:FKE-TEST_CHANNEL1": numpy.array([0.1, 0.2, 0.3, 0.4], dtype=numpy.float64),
        "H1:FKE-TEST_CHANNEL2": numpy.array([1, 2], dtype=numpy.int32),
    }
    block = SeriesBlock(
        1234567890 * Time.SECONDS,  # time in nanoseconds for first sample
        series,                     # the data to publish
        metadata,                   # the channel metadata
    )

    # publish timeseries
    publisher.publish(block)

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-0.12.0.tar.gz (83.4 kB view details)

Uploaded Source

Built Distribution

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

arrakis-0.12.0-py3-none-any.whl (80.7 kB view details)

Uploaded Python 3

File details

Details for the file arrakis-0.12.0.tar.gz.

File metadata

  • Download URL: arrakis-0.12.0.tar.gz
  • Upload date:
  • Size: 83.4 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-0.12.0.tar.gz
Algorithm Hash digest
SHA256 b84c90366929715b80d24d2138b2df72e5ffdadd722af3d25ecba4214386a5c2
MD5 4eef02fb92be0b79cd68ed927c65da80
BLAKE2b-256 240da468f1e543d7950b6b96600af30cd1670690be8f314634b1cbe2f983ddf4

See more details on using hashes here.

File details

Details for the file arrakis-0.12.0-py3-none-any.whl.

File metadata

  • Download URL: arrakis-0.12.0-py3-none-any.whl
  • Upload date:
  • Size: 80.7 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-0.12.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6737489525fe27afb17ae980a0e49195259bcd4a57e1e5146c6ef51549db06b6
MD5 117ff6cbe9e506230e852d9a68eacbd8
BLAKE2b-256 82e7fc8ddd9ec3af0ba67b31ad141c89fa866e5c8632c7906e1988b74d4f5c66

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