Skip to main content

Container image build repository for market data processing servers

Project description

License PyPI release
Build Status Publish to PyPI CodeQL Advanced Downloads GitHub last commit GitHub issues GitHub pull requests

kuhl-haus-mdp-servers

Container image build repository for market data processing servers

TL;DR

Non-business Massive (AKA Polygon.IO) accounts are limited to a single WebSocket connection per asset class and it has to be fast enough to handle messages in a non-blocking fashion or it'll get disconnected. The market data processing pipeline consists of loosely-coupled market data processing components so that a single WebSocket connection can handle messages fast enough to maintain a reliable connection with the market data provider.

Per, https://massive.com/docs/websocket/quickstart#connecting-to-the-websocket:

By default, one concurrent WebSocket connection per asset class is allowed. If you require multiple simultaneous connections for the same asset class, please contact support.

Components Summary

Non-business Massive (AKA Polygon.IO) accounts are limited to a single WebSocket connection per asset class and it has to be fast enough to handle messages in a non-blocking fashion or it'll get disconnected. The Market Data Listener (MDL) connects to the Market Data Source (Massive) and subscribes to unfiltered feeds. MDL inspects the message type for selecting the appropriate serialization method and destination Market Data Queue (MDQ). The Market Data Processors (MDP) subscribe to raw market data in the MDQ and perform the heavy lifting that would otherwise constrain the message handling speed of the MDL. This decoupling allows the MDP and MDL to scale independently. Post-processed market data is stored in the MDC for consumption by the Widget Data Service (WDS). Client-side widgets receive market data from the WDS, which provides a WebSocket interface to MDC pub/sub streams and cached data.

[Market Data Processing C4-V1.drawio.png]

Component Descriptions

Market Data Listener (MDL)

The MDL performs minimal processing on the messages. MDL inspects the message type for selecting the appropriate serialization method and destination queue. MDL implementations may vary as new MDS become available (for example, news).

MDL runs as a container and scales independently of other components. The MDL should not be accessible outside the data plane local network.

Market Data Queues (MDQ)

Purpose: Buffer high-velocity market data stream for server-side processing with aggressive freshness controls

  • Queue Type: FIFO with TTL (5-second max message age)
  • Cleanup Strategy: Discarded when TTL expires
  • Message Format: Timestamped JSON preserving original Massive.com structure
  • Durability: Non-persistent messages (speed over reliability for real-time data)
  • Independence: Queues operate completely independently - one queue per subscription
  • Technology: RabbitMQ

The MDQ should not be accessible outside the data plane local network.

Market Data Processors (MDP)

The purpose of the MDP is to process raw real-time market data and delegate processing to data-specific handlers. This separation of concerns allows MDPs to handle any type of data and simplifies horizontal scaling. The MDP stores its processed results in the Market Data Cache (MDC).

The MDP:

  • Hydrates the in-memory cache on MDC
  • Processes market data
  • Publishes messages to pub/sub channels
  • Maintains cache entries in MDC

MDPs runs as containers and scale independently of other components. The MDPs should not be accessible outside the data plane local network.

Market Data Cache (MDC)

Purpose: In-memory data store for serialized processed market data.

  • Cache Type: In-memory persistent or with TTL
  • Queue Type: pub/sub
  • Technology: Redis

The MDC should not be accessible outside the data plane local network.

Widget Data Service (WDS)

Purpose:

  1. WebSocket interface provides access to processed market data for client-side code
  2. Is the network-layer boundary between clients and the data that is available on the data plane

WDS runs as a container and scales independently of other components. WDS is the only data plane component that should be exposed to client networks.

Service Control Plane (SCP)

Purpose:

  1. Authentication and authorization
  2. Serve static and dynamic content via py4web
  3. Serve SPA to authenticated clients
  4. Injects authentication token and WDS url into SPA environment for authenticated access to WDS
  5. Control plane for managing application components at runtime
  6. API for programmatic access to service controls and instrumentation.

The SCP requires access to the data plane network for API access to data plane components.

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

kuhl_haus_mdp_servers-0.1.9.tar.gz (11.9 kB view details)

Uploaded Source

Built Distribution

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

kuhl_haus_mdp_servers-0.1.9-py3-none-any.whl (12.7 kB view details)

Uploaded Python 3

File details

Details for the file kuhl_haus_mdp_servers-0.1.9.tar.gz.

File metadata

  • Download URL: kuhl_haus_mdp_servers-0.1.9.tar.gz
  • Upload date:
  • Size: 11.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kuhl_haus_mdp_servers-0.1.9.tar.gz
Algorithm Hash digest
SHA256 2e2e5fa1747e59d4a6c2a39b1d692dd6be17fcad0b23c33258af33d02936873d
MD5 bbb97c5e7c5dfda6fdb6caf76ffdce29
BLAKE2b-256 695d3e02fcba4505a67a3b03348b8cf21b4d037c179e678fd8af9a6c8a5acad1

See more details on using hashes here.

Provenance

The following attestation bundles were made for kuhl_haus_mdp_servers-0.1.9.tar.gz:

Publisher: publish-to-pypi.yml on kuhl-haus/kuhl-haus-mdp-servers

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kuhl_haus_mdp_servers-0.1.9-py3-none-any.whl.

File metadata

File hashes

Hashes for kuhl_haus_mdp_servers-0.1.9-py3-none-any.whl
Algorithm Hash digest
SHA256 0af583378e699fdcf53b916630416a640d9aad867e8219e52240ff4b594786eb
MD5 1dcf6efb26f090acde40cc73297d0249
BLAKE2b-256 e512e55a3333b449760540e71b43cc02c16e08f6db3d69cee1d4fce3bca7dd63

See more details on using hashes here.

Provenance

The following attestation bundles were made for kuhl_haus_mdp_servers-0.1.9-py3-none-any.whl:

Publisher: publish-to-pypi.yml on kuhl-haus/kuhl-haus-mdp-servers

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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