Skip to main content

otelme pronounced "Oh, tell me"

Project description

otelme - pronounced "Oh, tell me"

A low-friction OpenTelemetry wrapper for Python apps. It comes with sugar over basic spanning and the tell magic receiver.

Usage

Use context managers or decorators to automatically create scoped spans:

with telme.tell('update_user_record'):
    telme.tell('a') | 'b'
    ...

@telme.tell
def myfunc():
    ...

@telme.tell('different_name')
def myfunc():
    ...

Save the user friend count before adding to it and saving it to a variable

new_count = telme.tell('friends') @ len(user.friends) + 1

Save the result of count + 1 as the attribute 'newcount' on the current span

telme.tell('newcount') + count
new_count = telme.tell('newcount') + 1

Use a splat (*) operator to add a whole dict a JSON attribute on the current trace

telme.tell('explosion') * {'bang': 'loud', 'flame': 'big'}
# adds span attr: {'explosion': '{"bang": "loud", "flame": "big"}'

Use double-splat (**) operator to hoist a dict by its keys on the current trace

telme.tell('explosion') ** {'bang': 'loud', 'flame': 'big'}
# adds span attrs: {'explosion.bang': 'loud', 'explosion.flame': 'big'}

Use notify with the splat (*) operator to add a dict as an event on the current trace

telme.notify('explosion') ** {'bang': 'loud', 'flame': 'big'}
# adds new event `explosion` with attrs: {'bang': 'loud', 'flame': 'big'}

Inspired by pipe, q, and the rollup_field support in Honeycomb's beeline.

Contributing

All help is welcome, especially help understanding how otelme is used and what other use cases we can help with. Not all pull requests will be accepted, before opening a PR with a feature please open an issue to discuss it to avoid doing work that can't be upstreamed.

License

otelme is available under the MIT license, see LICENSE for details.

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

otelme-0.0.4.tar.gz (11.9 kB view hashes)

Uploaded Source

Built Distribution

otelme-0.0.4-py3-none-any.whl (5.4 kB view hashes)

Uploaded Python 3

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