Metrics system for generating statistics about your app
Project description
Markus is a metrics generation library for generating statistics about your app.
- Code:
- Issues:
- License:
MPL v2
- Documentation:
- Status:
Alpha
Goals
Markus makes it easier to add metrics generation to your app by:
providing multiple backends (Datadog statsd, statsd, logging, and so on) for sending data to multiple places
sending metrics to multiple backends
providing a testing framework for easy testing
providing a decoupled infrastructure making it easier to use metrics without having to worry about making sure your metrics client is configured and instantiated before the things that want to use it; it’s similar to the Python logging module in this way
Install
To install Markus, run:
$ pip install markus
(Optional) To install the requirements for the markus.backends.datadog.DatadogMetrics backend:
$ pip install markus[datadog]
Quick start
Similar to using the logging library, every Python module can create a MetricsInterface (loosely equivalent to a Python logging logger) at any time including at module import time and use that to generate metrics.
For example:
import markus metrics = markus.get_metrics(__name__)
Creating a MetricsImplementation using __name__ will cause it to generate all stats keys with a prefix determined from __name__ which is a dotted Python path to that module.
Then you can use the MetricsImplementation anywhere in that module:
@metrics.timer_decorator('chopping_vegetables') def some_long_function(vegetable): for veg in vegetable: chop_vegetable() metrics.incr('vegetable', 1)
At application startup, configure Markus with the backends you want to use to publish metrics and any options they require.
For example, lets configure metrics to publish to logs and Datadog:
import markus markus.configure( backends=[ { # Log metrics to the logs 'class': 'markus.backends.logging.LoggingMetrics', }, { # Log metrics to Datadog 'class': 'markus.backends.datadog.DatadogMetrics', 'options': { 'statsd_host': 'example.com', 'statsd_port': 8125, 'statsd_namespace': '' } } ] )
When you’re writing your tests, use the MetricsMock to make testing easier:
import markus from markus.testing import MetricsMock def test_something(): with MetricsMock() as mm: # ... Do things that might publish metrics # This helps you debug and write your test mm.print_records() # Make assertions on metrics published assert mm.has_metric(markus.INCR, 'some.key', {'value': 1})
History
1.0 (October 30th, 2017)
Features
Added support for Python 2.7.
Added a markus.backends.statsd.StatsdMetrics backend that uses pystatsd client for statsd pings. Thank you, Javier!
Bug fixes
Added LoggingRollupMetrics to docs.
Mozilla has been running Markus in production for 6 months so we can mark it production-ready now.
0.2 (April 19th, 2017)
Features
Added a markus.backends.logging.LoggingRollupMetrics backend that rolls up metrics and does some light math on them. Possibly helpful for light profiling for development.
Bug fixes
Lots of documentation fixes. Thank you, Peter!
0.1 (April 10th, 2017)
Initial writing.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.