Enrich with OpenTelemetry API
Odigos will automatically instrument your services and record semantic spans from popular modules. Many users find the automatic instrumentation data sufficient for their needs.
However, if there is anything specific to your application that you want to record, you can enrich the data by adding custom spans to your code.
This is sometimes referred to as manual instrumentation
.
Use Cases
Examples of custom spans you might want to add to your code include:
- Spans for the execution of some potentially heavy or slow computation in you service.
- Tracing for internal or third party libraries for which you don’t have automatic or integrated instrumentation.
- Spans to describe some logical operations in your business logic that are meaningful in your domain.
Required Dependencies
Install the API from PyPI using pip:
Creating Spans
To create a span, use the tracer
object from the opentelemetry.trace
module. The tracer
object is a factory for creating spans.
Important Notes:
- Assign meaningful names to spans: Use descriptive names for spans, (such as the function name) to clearly describe the operations they represent. This helps anyone examining the trace to easily understand the span’s purpose and context.
- Avoid dynamic, high cardinality data in span names: Do not include dynamic data such as IDs in the span name, as this can cause performance issues and make the trace harder to read. Instead, use static, descriptive names for spans and record dynamic information in span attributes. This ensures better performance and readability of the trace.
Recording Span Attributes
Span attributes are key-value pairs that record additional information about an operation, which can be useful for debugging, performance analysis, or troubleshooting
Examples:
- User ID, organization ID, Account ID or other identifiers.
- Inputs - the relevant parameters or configuration that influenced the operation.
- Outputs - the result of the operation.
- Entities - the entities or resources that the operation interacted with.
Attribute names are lowercased strings in the form my_application.my_attribute
, example: my_service.user_id
.
Read more here
To record attributes, use the set_attribute
method on the span object.
Important Notes:
- Be cautious when recording data: Avoid including PII (personally identifiable information) or any data you do not wish to expose in your traces.
- Attribute cost considerations: Each attribute affects performance and processing time. Record only what is necessary and avoid superfluous data.
- Use static names for attributes: Avoid dynamic content such as IDs in attribute keys. Use static names and properly namespace them (scope.attribute_name) to provide clear context for downstream consumers.
- Adhere to OpenTelemetry semantic conventions: Prefer using namespaces and attribute names from the OpenTelemetry semantic conventions to enhance data interoperability and make it easier for others to understand.
Recording Errors
To easily identify and monitor errors in your traces, the Span object includes a status field that can be used to mark the span as an error. This helps in spotting errors in trace viewers, sampling, and setting up alerts.
If an operation you are tracing fails, you can mark the span’s status as an error and record the error details within the span. Here’s how you can do it:
- An exception has been raised to demonstrate an error that occurred in your code.
Additional Information
For more use cases, see the OpenTelemetry Python API documentation.