Skip to main content

Convenience wrapper for OpenTelemetry

Project description

barium-meal

Python Wrapper for OpenTelemetry written to scratch the itch of needing to use the same / similar code across several Google Cloud Functions and wanting to abstract away from tracing / logging so I can mix and match the two.

Some of these cloud functions are invoked via HTTP, others from Pub/Sub messages.

For Pub/Sub I have jury-rigged persisting the state of a Span to propagate between processes. To ensure that a trace that goes from function to function via pub/sub remains contiguous.

I'm sure there is a better way of doing this but this is good enough for my purposes and by putting my solution out in the wild I'm hoping to get feedback to help improve it.

For http I have used the W3C Trace Context Level1 Recommendation from 6 February 2020. I rolled my own here as I didn't find an existing Python implementation. Again if I have missed something and someone would like to put me right that would be great!

Installation

pip install barium-meal

Usage

The tests are the best guide to usage. In the interests of keeping things DRY please take a look there.

Running the tests

In a new virtual environment:

python setup.py develop
pytest

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

File details

Details for the file barium-meal-0.0.13.macosx-10.15-x86_64.tar.gz.

File metadata

  • Download URL: barium-meal-0.0.13.macosx-10.15-x86_64.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.56.2 CPython/3.8.6

File hashes

Hashes for barium-meal-0.0.13.macosx-10.15-x86_64.tar.gz
Algorithm Hash digest
SHA256 813f6e6188e206fd50907a858ae2e59ebdaa9d463026ef75e3b57259f522b343
MD5 27c198ea83cbe4f4c886e007ec2eb515
BLAKE2b-256 4e99e9278b6c0ce1694fa25ebfe640f8af956e50c50b32bc0e04e4d5fcc9984f

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