Skip to main content

Monasca statsd Python client

Project description

Team and repository tags

https://governance.openstack.org/tc/badges/monasca-statsd.svg

A Monasca-Statsd Python Client.

Quick Start Guide

First install the library with pip or easy_install:

# Install in system python ...
sudo pip install monasca-statsd

# .. or into a virtual env
pip install monasca-statsd

Then start instrumenting your code:

# Import the module.
import monascastatsd as mstatsd

# Create the connection
conn = mstatsd.Connection(host='localhost', port=8125)

# Create the client with optional dimensions
client = mstatsd.Client(connection=conn, dimensions={'env': 'test'})

NOTE: You can also create a client without specifying the connection and it will create the client
with the default connection information for the monasca-agent statsd processor daemon
which uses host='localhost' and port=8125.

client = mstatsd.Client(dimensions={'env': 'test'})

# Increment and decrement a counter.
counter = client.get_counter(name='page.views')

counter.increment()
counter += 3

counter.decrement()
counter -= 3

# Record a gauge 50% of the time.
gauge = client.get_gauge('gauge', dimensions={'env': 'test'})

gauge.send('metric', 123.4, sample_rate=0.5)

# Sample a histogram.
histogram = client.get_histogram('histogram', dimensions={'test': 'True'})

histogram.send('metric', 123.4, dimensions={'color': 'red'})

# Time a function call.
timer = client.get_timer()

@timer.timed('page.render')
def render_page():
    # Render things ...
    pass

# Time a block of code.
timer = client.get_timer()

with timer.time('t'):
    # Do stuff
    time.sleep(2)

# Add dimensions to any metric.
histogram = client.get_histogram('my_hist')
histogram.send('query.time', 10, dimensions = {'version': '1.0', 'environment': 'dev'})

Feedback

To suggest a feature, report a bug, or participate in the general discussion, head over to StoryBoard.

License

See LICENSE file. Code was originally forked from Datadog’s dogstatsd-python, hence the dual license.

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

monasca-statsd-2.0.0.tar.gz (21.5 kB view details)

Uploaded Source

Built Distribution

monasca_statsd-2.0.0-py2.py3-none-any.whl (20.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file monasca-statsd-2.0.0.tar.gz.

File metadata

  • Download URL: monasca-statsd-2.0.0.tar.gz
  • Upload date:
  • Size: 21.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.20.1 setuptools/20.7.0 requests-toolbelt/0.9.1 tqdm/4.40.2 CPython/3.5.2

File hashes

Hashes for monasca-statsd-2.0.0.tar.gz
Algorithm Hash digest
SHA256 6f9c587064992c5d2636a4c29d2812b56561156ae3af78f507e62ff7e31fe5f4
MD5 2f479d4ea353790525e59c72ae5980c4
BLAKE2b-256 9d1d94c80e2a2851a3ff60a462edad651507c98c78c5213175b45404ed110365

See more details on using hashes here.

File details

Details for the file monasca_statsd-2.0.0-py2.py3-none-any.whl.

File metadata

  • Download URL: monasca_statsd-2.0.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 20.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.20.1 setuptools/20.7.0 requests-toolbelt/0.9.1 tqdm/4.40.2 CPython/3.5.2

File hashes

Hashes for monasca_statsd-2.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 ed80cbfe3e7e08063a12df83589af5f6749948408035158f15b9ff52018c97cf
MD5 8259f704a227b8298ce0dee462c49af1
BLAKE2b-256 4df9a8fc1a2b9a9fc7fc2446ed6c9dd57f87b387fcb99d9666de373b9c53579e

See more details on using hashes here.

Supported by

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