Correlating Python Logs and Traces
Cette page n'est pas encore disponible en français, sa traduction est en cours.
Si vous avez des questions ou des retours sur notre projet de traduction actuel, 
n'hésitez pas à nous contacter.
Injection
Standard library logging
To correlate your traces with your logs, complete the following steps:
- Activate automatic instrumentation.
- Include required attributes from the log record.
Step 1 - Activate automatic instrumentation
Activate automatic instrumentation using one of the following options:
Option 1: Library Injection:
- Follow the instructions in Library Injection to set up tracing.
- For older trace versions (ddtrace<3.11) set the environment variableDD_LOGS_INJECTION=truein the applicationdeployment/manifestfile.
Option 2: ddtrace-run:
- Import ddtrace into the application.
- Run the application with ddtrace-run(for example,ddtrace-run python appname.py).
Option 3: import ddtrace.auto:
- Import ddtrace.auto into the application. This will automatically enable the logging, logback, loguru, and/or structlog integration.
Step 2 - Include required attributes
Update your log format to include the required attributes from the log record.
Include the dd.env, dd.service, dd.version, dd.trace_id and
dd.span_id attributes for your log record in the format string.
Here is an example using logging.basicConfig to configure the log injection. Note ddtrace-run or import ddtrace.auto are required:
import logging
from ddtrace import tracer
FORMAT = ('%(asctime)s %(levelname)s [%(name)s] [%(filename)s:%(lineno)d] '
          '[dd.service=%(dd.service)s dd.env=%(dd.env)s dd.version=%(dd.version)s dd.trace_id=%(dd.trace_id)s dd.span_id=%(dd.span_id)s] '
          '- %(message)s')
logging.basicConfig(format=FORMAT)
log = logging.getLogger(__name__)
log.level = logging.INFO
@tracer.wrap()
def hello():
    log.info('Hello, World!')
hello()
To learn more about logs injection, read the ddtrace documentation.
No standard library logging
By default, ddtrace.trace.tracer.log_correlation returns dd.env=<ENV> dd.service=<SERVICE> dd.version=<VERSION> dd.trace_id=<TRACE_ID> dd.span_id=<SPAN_ID>.
from ddtrace import tracer
log_correlation_dict = tracer.get_log_correlation_context()
As an illustration of this approach, the following example defines a function as a processor in structlog to add tracer fields to the log output:
import ddtrace
from ddtrace import tracer
import structlog
def tracer_injection(logger, log_method, event_dict):
    # get correlation ids from current tracer context
    event_dict.update(tracer.get_log_correlation_context())
    return event_dict
structlog.configure(
    processors=[
        tracer_injection,
        structlog.processors.JSONRenderer()
    ]
)
log = structlog.get_logger()
Once the logger is configured, executing a traced function that logs an event yields the injected tracer information:
>>> traced_func()
{"event": "In tracer context", "dd.trace_id": 9982398928418628468, "dd.span_id": 10130028953923355146, "dd.env": "dev", "dd.service": "hello", "dd.version": "abc123"}
Note: If you are not using a Datadog Log Integration to parse your logs, custom log parsing rules need to ensure that dd.trace_id and dd.span_id are being parsed as strings and remapped using the Trace Remapper. For more information, see Correlated Logs Not Showing Up in the Trace ID Panel.
See the Python logging documentation to ensure that the Python Log Integration is properly configured so that your Python logs are automatically parsed.
Further Reading
Documentation, liens et articles supplémentaires utiles: