A low-friction OpenTelemetry wrapper for Python apps. It comes with sugar over basic spanning and the tell
magic receiver.
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.
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.
otelme
is available under the MIT license, see LICENSE
for details.