This release of the Python agent includes an update to the API for recording exceptions, default request attributes, optional function trace attributes, and bug fixes.
newrelic.agent.record_exception now adds attributes to spans
The public API method
newrelic.agent.record_exceptionnow attaches exception details to the currently executing span. Spans with error details are now highlighted red in the distributed tracing UI. Also, the attributes
error.messageare added to the span. If multiple errors are recorded for a single span, only the final error's attributes will be added to the span.
Note: Exceptions recorded on spans may be double counted in the distributed tracing UI.
New default web request attributes.
The previously optional attributes
request.headers.userAgentare now included by default on all web transactions. These attributes can be excluded through agent configuration.
peer.address and peer.hostname can now be excluded from spans through configuration
peer.address and peer.hostname may be excluded from span events through
attribute.excludeoptions in the agent configuration.
Fix issue which could potentially lead to missing event data
When the agent was shutting down, event harvest may have been skipped causing any events captured in the final 5 seconds of application execution to be discarded. This has now been fixed.
Runtime instrumentation error messages for calling
__enter__were erroneously logged
Under certain conditions, the agent may have logged an error message for transaction
__exit__being called before trace
__enter__. This error message is now printed only if the error condition is true.
Known issues and workarounds
- If a .NET agent is initiating distributed traces as the root service, you must update that .NET agent to version 8.24 or later before upgrading your downstream New Relic Python agents to this agent release.