Skip to main content

No project description provided

Project description

Ebb Time Series

EbbCarbon package for working with time series data and databases. Time series data is a type of data that is collected over certain time intervals and is used to analyze trends, patterns, and behavior over time. This ebb-time-series package is built to be used in tandem with the ebb-events package to assist in the flow of time series data from event messages to various time series databases and and to read from various time series databases to export and analyze the data.

For writing to time series databases: Once an event is consumed off of a message broker, use this package to write the event's data to your desired database for storage and further analysis. The combined use of these two EbbCarbon packages will enable you to streamline your data pipeline from edge node all the way to the cloud. NOTE: In order to use this package, the event writers expect to receive ebb-event EventConsumer objects with payloads of the ebb-event structure.

For reading and exporting from time series databases: TBD...

Use:

Install the ebb-time-series package from pip installer via: pip install ebb-time-series. Use ebb-time-series to write your event message data to a database.

from ebb_time_series.writers.aws_timestream_data_writer import AwsTimestreamDataWriter
from ebb_events.consumers.event_consumer import EventConsumer

my_ebb_event_payload = {...}  # payload matching ebb-event structure from message broker
my_consumer = EventConsumer(payload=my_ebb_event_payload)
my_writer = AwsTimestreamDataWriter(aws_region="my-aws-region", db_name="my-db-name", table_name="my-table-name")

# Parsing of data in my_consumer is abstracted away in this write_event_records method
try:
    my_writer.write_event_records(consumer=my_consumer)
except EbbTimeSeriesWriteException
    # handle exception here

Data Structure:

The time series writer parses the data in the event payload expecting the data to follow this structure:

{
    "my_variable_1": {
        "value": ___,
        "unites": ___,
    },
    "my_variable_2": {
        "value": ___,
        "unites": ___,
    },
    "my_variable_3": {
        "value": ___,
        "unites": ___,
    },
    ...
}

Release new version to PyPI:

In order to release a new version to PyPI, run the following command pre-merging of PR:

  1. poetry version patch/minor/major
  2. poetry build

Once the PR is approved and merged. Checkout main, pull the latest, and run:

  1. poetry publish

Check that your new release was successfully pushed to PyPI here!

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

ebb_time_series-0.3.6a11.tar.gz (8.3 kB view details)

Uploaded Source

Built Distribution

ebb_time_series-0.3.6a11-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file ebb_time_series-0.3.6a11.tar.gz.

File metadata

  • Download URL: ebb_time_series-0.3.6a11.tar.gz
  • Upload date:
  • Size: 8.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.10.12 Darwin/23.4.0

File hashes

Hashes for ebb_time_series-0.3.6a11.tar.gz
Algorithm Hash digest
SHA256 e324d2ba4960b6cf9ccfa5e93e9784828a613f2ced314df44373d2e608b5de0d
MD5 1fcff76cc99a9386b631af0b6cb8dd85
BLAKE2b-256 f002b72e177a3555e8659ac65acd96c6c48ba1eca8edaa622efec624ac8a29fb

See more details on using hashes here.

File details

Details for the file ebb_time_series-0.3.6a11-py3-none-any.whl.

File metadata

File hashes

Hashes for ebb_time_series-0.3.6a11-py3-none-any.whl
Algorithm Hash digest
SHA256 4e138bef58b82efe38b043d65e5b004d37b78e44767ef4af0301c16e51ae6a7a
MD5 b2b9dcd669a63119c3d4f4b2c1dc6935
BLAKE2b-256 b511c5dbdab72fe89f9739b2f05481121b7d5d4cfdcdfa69bd308ff888eef24a

See more details on using hashes here.

Supported by

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