Skip to main content

Felicien is you companion to retrieve timeseries from a TSDB, to transform it in various format and to push it to a TSDB.

Project description

Felicien

Felicien is you companion to retrieve timeseries from a TSDB, to transform it in various format and to push it to a TSDB. Supported TSDB are Prometheus compatible (Prometheus, VictoriaMetrics, ...).

Installation

Felicien is available on PyPI:

$ python -m pip install felicien

Felicien officially supports Python 3.11+.

Usage

Felicien helps you to connect to a TSDB, and to play with timeseries.

>>> from felicien import FeliConnector
>>> tsdb = FeliConnector(url="https://my.victoriametrics.instance", tsdb="victoriametrics")
>>> tsdb
FeliConnector([victoriametrics]{https://my.victoriametrics.instance})

>>> ts_scalar = tsdb.get_timeserie(metric='vm_cache_entries{job=~"victoriametrics", instance=~"victoriametrics:8428", type="storage/hour_metric_ids"}')
>>> ts_scalar
FeliTS(vm_cache_entries{instance:"victoriametrics:8428", job:"victoriametrics", type:"storage/hour_metric_ids"}, 1 datapoints)
>>> ts_scalar.as_prometheus()
{'metric': {'__name__': 'vm_cache_entries',
  'instance': 'victoriametrics:8428',
  'job': 'victoriametrics',
  'type': 'storage/hour_metric_ids'},
 'values': [17805.0],
 'timestamps': [1713606731000]}

>>> ts_vector = tsdb.get_timeserie(metric='vm_cache_entries{job=~"victoriametrics", instance=~"victoriametrics:8428", type="storage/hour_metric_ids"}[1h]')
>>> ts_vector
FeliTS(vm_cache_entries{job:"victoriametrics", type:"storage/hour_metric_ids", instance:"victoriametrics:8428"}, 60 datapoints)
>>> ts_vector.frequency
Timedelta('0 days 00:01:00')
>>> ts_vector.data.describe()
count       60.000000
mean     17768.150000
std          5.580915
min      17766.000000
25%      17766.000000
50%      17766.000000
75%      17767.000000
max      17805.000000
dtype: float64
>>> ts_vector.trim_by_size(boundary=10, keep="left")
2024-04-20 09:03:40.177000046    17766.0
2024-04-20 09:04:40.177000046    17766.0
2024-04-20 09:05:40.177000046    17766.0
2024-04-20 09:06:40.177000046    17766.0
2024-04-20 09:07:40.177000046    17766.0
2024-04-20 09:08:40.177000046    17766.0
2024-04-20 09:09:40.177000046    17766.0
2024-04-20 09:10:40.177000046    17766.0
2024-04-20 09:11:40.177000046    17766.0
2024-04-20 09:12:40.177000046    17766.0
dtype: float64

Main features

  • Connect to a TSDB, and check connectivity
  • Get a timeserie and store it in a Pandas Series
  • Estimate frequency of a timeserie
  • Trim a timeserie by date or by size
  • Transform the timeserie in a pandas.DataFrame
  • Delete a timeserie in a TSDB
  • Import a timeserie into a TSDB
  • Normalize a timeserie on its frequency

License

MIT

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

felicien-0.8.0.tar.gz (8.9 kB view details)

Uploaded Source

Built Distribution

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

felicien-0.8.0-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

File details

Details for the file felicien-0.8.0.tar.gz.

File metadata

  • Download URL: felicien-0.8.0.tar.gz
  • Upload date:
  • Size: 8.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.11.9 Linux/5.15.154+

File hashes

Hashes for felicien-0.8.0.tar.gz
Algorithm Hash digest
SHA256 0cad2b4bf081f7ad03deb5ea0a0b593473af30506a084a5fae8eea6da8a3a9b3
MD5 52010df2b91c1a8cd11a388d5d4fdeec
BLAKE2b-256 7fc85b694b0eb713b92b75c665d4aa2614ef47ed625059462fadc9483b40485e

See more details on using hashes here.

File details

Details for the file felicien-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: felicien-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 9.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.11.9 Linux/5.15.154+

File hashes

Hashes for felicien-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 74d4dbdf411fe3789d8e8360adbbd6a3ccb8315b51b5d06f9a46278e67424dd7
MD5 e52a574d3f8a2a20967a2f3927cb1308
BLAKE2b-256 2587e689e99d29b957b37d3f63c317fdf2b4e4f3d05ef6c7b7b198d11d4e84a2

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