Skip to main content

AWS CloudWatch client library to send metrics conveniently and efficiently

Project description

Amazon Web Services Cloud Watch Metrics Library

https://img.shields.io/pypi/v/awsme.svg https://img.shields.io/travis/peterdemin/awsme.svg Updates

Configurable client library, that supports asynchronous and buffered sending of AWS cloud watch metrics.

Installation

By default awsme is installed without boto3 dependency to make it deploy faster in AWS Lambda environment (See #3 <https://github.com/peterdemin/awsme/issues/3> for details).

If you run awsme outside of Lambda, use following command to activate boto3 dependency:

pip install awsme[boto3]

Usage

from awsme import create_cloud_watch
cloud_watch = create_cloud_watch(
    namespace='Application',
    dimensions={'version': '1.0.0'},
)
cloud_watch.log('metric', dimensions={'key': 'dim'}, value=123)

Create Options

create_cloud_watch accepts following arguments:

  • asynchronous (optional bool): if True (default), send metrics from a separate thread.

  • buffered (optional bool): if True (default), metrics will be accumulated in a buffer and sent in batches.

  • dummy (optional bool): if True, ignore two previous options and create dummy recorder. False by default.

  • dimensions: (optional Dict[str, str]): dictionary of default dimensions, that will be attached to all metrics.

  • All other kwargs will be bypassed to boto3.client('cloudwatch', **kwargs)

Log Options

CloudWatch, returned by create_cloud_watch has two public methods. The primary method is log. It’s arguments:

  • name (required str): name of the metric.

  • dimensions (optional Dict[str, str]): additional dimensions, that will be added to default dimension from factory.

  • value (optional float): metric’s value, 1 by default.

  • unit (optional str): metric unit, e.g. Count, Seconds, Bytes, see AWS docs for a complete list of valid values.

  • storage_resolution (optional int): metric storage resolution in seconds, 60 by default.

Flushing

If create_cloud_watch was called with buffered=True (default) then you may want to forcefully flush the internal metrics buffer. In a standard application this will likely not be necessary, as the buffer will auto-flush atexit. However, if your application is running as an AWS Lambda function, the execution of the Lambda function will be “frozen” when the function completes, preventing exiting and thus flushing. In this use case, you will need to forcibly flush the buffer by calling flush. It’s argument:

  • complete (optional bool): if True (default), perform a complete flush.

AWS configuration

Awsme uses boto3 library, that takes configuration from environment variables and configuration files. To check, that you have everything configured properly to send metrics, use included command-line tool:

$ awsme-test
...
Successfully sent metric "awsme-test" to "Test Namespace"

Credits

This package was created with Cookiecutter and the elgertam/cookiecutter-pipenv project template, based on audreyr/cookiecutter-pypackage.

History

0.2.2 (2019-01-24)

  • Added asynchronous recorder and user documentation

0.1.0 (2018-11-13)

  • First release on PyPI.

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

awsme-1.0.0.tar.gz (33.3 kB view details)

Uploaded Source

Built Distribution

awsme-1.0.0-py2.py3-none-any.whl (9.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file awsme-1.0.0.tar.gz.

File metadata

  • Download URL: awsme-1.0.0.tar.gz
  • Upload date:
  • Size: 33.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.3

File hashes

Hashes for awsme-1.0.0.tar.gz
Algorithm Hash digest
SHA256 ef97279d2638ed348786af517f4fedc4ede6bc022388fe07ddd1c3a0cddc9a32
MD5 85239e6ce3e593f293cd5b5c0c8fcc03
BLAKE2b-256 187d0ffac18e358b9cfd9743bd0d7aae2449937e2577d79dea255edd9088491b

See more details on using hashes here.

File details

Details for the file awsme-1.0.0-py2.py3-none-any.whl.

File metadata

  • Download URL: awsme-1.0.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 9.6 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.3

File hashes

Hashes for awsme-1.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 cce8899e8369a5f0dbe1f00fd203eeda904d7a1369ce53b2ba5cdca34f99b565
MD5 0278424b24fc1e5d54c82b5eb642022e
BLAKE2b-256 ba9aa2d1387ec1408c8b3335c66817fc7210e8799b20c78bce79b2ac71b09a8b

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