Micro metrics library for ffwd
Project description
shumway
A micro library for sending metrics to a FFWD agent.
Requirements
- Python 3.7. Tests pass on 3.7, and 3.8, and on the latest PyPy3 at build-time.
- Support for Linux & OS X
To Use
(env) $ pip install shumway
Counters
Create a default counter and send to FFWD:
import shumway
mr = shumway.MetricRelay(SERVICE_NAME)
mr.incr(METRIC_NAME)
mr.flush()
Initialize a counter with a value
import shumway
mr = shumway.MetricRelay(SERVICE_NAME)
counter = shumway.Counter(metric_name, SERVICE_NAME, value=10)
mr.set_counter(metric_name, counter)
mr.incr(metric_name)
mr.flush()
Different increment values
Create a named counter and increment by a value different than 1:
import shumway
mr = shumway.MetricRelay(SERVICE_NAME)
mr.incr(METRIC_NAME, 2)
mr.flush()
Custom Counter Attributes
Set custom attributes for metrics:
import shumway
mr = shumway.MetricRelay(SERVICE_NAME)
counter = shumway.counter(metric_name, SERVICE_NAME,
{attr_1: value_1,
attr_2: value_2})
mr.set_counter(metric_name, counter)
mr.incr(metric_name)
mr.flush()
NB: If you use duplicate names when calling set_counter
it will overwrite the
counter. You will likely want to use a unique metric name for each set of
attributes you are setting.
Timers
import shumway
mr = shumway.MetricRelay(SERVICE_NAME)
timer = mr.timer('timing-this-thing')
with timer:
...task you want to time
mr.flush()
Custom Timer Attributes
Timers can also be created independently in order to set custom attributes:
import shumway
mr = shumway.MetricRelay(SERVICE_NAME)
timer = shumway.Timer('timing-this-thing', SERVICE_NAME,
{'attr_1': value_1, 'attr_2': value_2})
with timer:
# ...task you want to time
mr.set_timer('timing-this-thing', timer)
mr.flush()
Interacting with metrics objects
Metric objects (like a timer) themselves have a flush
function as well as a as_dict
function
import shumway
timer = shumway.Timer('timing-this-thing', SERVICE_NAME,
{'attr_1': value_1, 'attr_2': value_2})
timer_as_dict = timer.as_dict()
timer.flush(lambda dict: do_smth())
Default attributes for non-custom metrics
MetricRelay can create metrics with a common set of attributes as well:
import shumway
attributes = dict(foo='bar')
mr = shumway.MetricRelay(SERVICE_NAME, default_attributes=attributes)
Resource Identifiers
MetricsRelay and send resource identifiers as well:
import shumway
resources = dict(podname='my_ephemeral_podname')
mr = shumway.MetricRelay(SERVICE_NAME, default_resources=resources)
For more on resource identifiers see Heroic Documentation
Sending Metrics
There are two ways to send metrics to the ffwd
agent:
Emit one metric
You can emit a one-off, event-type metric immediately:
import shumway
mr = shumway.MetricRelay('my-service')
# some event happened
mr.emit('a-successful-event', 1)
# some event happened with attributes
mr.emit('a-successful-event', 1, {'attr_1': value_1, 'attr_2': value_2})
# an event with a multiple value happened
mr.emit('a-successful-event', 5)
Flushing all metrics
For batch-like metrics, you can flush metrics once you're ready:
import shumway
mr = shumway.MetricRelay('my-service')
# measure all the things
# time all the things
if not dry_run:
mr.flush()
Existing Metrics
Check for existence of metrics in the MetricRelay with in
:
>>> import shumway
>>> mr = shumway.MetricRelay('my-service')
>>> counter = shumway.Counter('thing-to-count', 'my-service', value=5)
>>> mr.set_counter('thing-to-count', counter)
>>> 'thing-to-count' in mr
True
>>> 'not-a-counter' in mr
False
Custom FFWD agents
By default, shumway
will send metrics to a local ffwd
agent at 127.0.0.1:19000
.
If your ffwd
agent is elsewhere, then pass that information through when initializing the MetricRelay
:
import shumway
mr = shumway.MetricRelay(SERVICE_NAME, ffwd_ip='10.99.0.1', ffwd_port=19001)
# do the thing
Sending Metrics via HTTP to FFWD
Instead of via UDP it is also possible to send metrics via HTTP by setting the use_http
flag:
import shumway
mr = shumway.MetricRelay(SERVICE_NAME,
ffwd_host="http://my-metrics-api.com",
ffwd_port=8080,
ffwd_path="/v1/metrics",
use_http=True)
The ffwd_host
parameter should be the HTTP endpoint and optionally ffwd_path
can be set to specify the path.
Changes
Unreleased
4.0.0
- Remove python3.6 and use python3.7 as a minimum required version
3.0.0 - 3.0.2
- Major version bump due to dependency updates and change to supported Python versions.
2.0.0
- Positional arguments for
Meter()
,Counter()
,Timer()
, andMetricRelay(...).emit()
were changed to addresources
. If using only named arguments this should not be a problem.
Developer Setup
For development and running tests, your system must have all supported versions of Python installed. We suggest using pyenv.
Setup
$ git clone git@github.com:spotify/shumway.git && cd shumway
# make a virtualenv
(env) $ pip install -r dev-requirements.txt
Running tests
To run the entire test suite:
# outside of the virtualenv
# if tox is not yet installed
$ pip install tox
$ tox
If you want to run the test suite for a specific version of Python:
# outside of the virtualenv
$ tox -e py37
To run an individual test, call nosetests
directly:
# inside virtualenv
(env) $ nosetests test/metrics_test.py
Code of Conduct
This project adheres to the Open Code of Conduct. By participating, you are expected to honor this code.
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
Built Distribution
File details
Details for the file shumway-4.0.0.tar.gz
.
File metadata
- Download URL: shumway-4.0.0.tar.gz
- Upload date:
- Size: 12.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 88963721855a8a1de28438fbe0f825e179126631303dfb3c5c331035a9936bd9 |
|
MD5 | aa81de71c178c9eda113f663c5e95a00 |
|
BLAKE2b-256 | 4181b63b5b2a3170af7b77088eaf76770144afd3b0b25b223084783b1ba19538 |
File details
Details for the file shumway-4.0.0-py2.py3-none-any.whl
.
File metadata
- Download URL: shumway-4.0.0-py2.py3-none-any.whl
- Upload date:
- Size: 12.8 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6d4eae66baeee3fd2bc81217adb4084aa13ccf324e92ab751a9c46349cc9d4df |
|
MD5 | c82d2c23b454cf068a4991cd9334f99a |
|
BLAKE2b-256 | 9e56f67e3f271294a267d7f0a49e5faf83eb580a72fad04d67a59d167808e71d |