Skip to content

Commit

Permalink
Integration Exception Tracking
Browse files Browse the repository at this point in the history
Report only an error or an exception with a stack trace. Added tags and stack trace (without redaction)
  • Loading branch information
ygree committed Dec 14, 2024
1 parent 26cec0a commit ee669be
Showing 1 changed file with 21 additions and 8 deletions.
29 changes: 21 additions & 8 deletions ddtrace/internal/logger.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import collections
import logging
import os
import traceback
import typing
from typing import Optional # noqa:F401
from typing import cast # noqa:F401
Expand Down Expand Up @@ -121,10 +122,12 @@ def __init__(self, *args, **kwargs):
self.rate_limit = 60

self.telemetry_log_buckets = None
if _TelemetryConfig.LOG_COLLECTION_ENABLED and self.name.startswith("ddtrace.contrib."):
self.telemetry_log_buckets = collections.defaultdict(
lambda: DDLogger.LoggingBucket(0, 0)
) # type: DefaultDict[Tuple[str, int, str, int], DDLogger.LoggingBucket]
if _TelemetryConfig.LOG_COLLECTION_ENABLED:
if self.name.startswith("ddtrace.contrib."):
# Collect only errors logged within the integration package
self.telemetry_log_buckets = collections.defaultdict(
lambda: DDLogger.LoggingBucket(0, 0)
) # type: DefaultDict[Tuple[str, int, str, int], DDLogger.LoggingBucket]

def handle(self, record):
# type: (logging.LogRecord) -> None
Expand All @@ -149,7 +152,6 @@ def handle(self, record):
telemetry.telemetry_writer.add_error(1, record.msg % record.args, full_file_name, record.lineno)

if self.telemetry_log_buckets is not None:
# TODO exclude debug logs:: and record.levelno > logging.DEBUG:
self._report_telemetry_log(record)

# If rate limiting has been disabled (`DD_TRACE_LOGGING_RATE=0`) then apply no rate limit
Expand Down Expand Up @@ -190,6 +192,7 @@ def handle(self, record):
self.buckets[key] = DDLogger.LoggingBucket(logging_bucket.bucket, logging_bucket.skipped + 1)

def _report_telemetry_log(self, record):
# type: (logging.LogRecord) -> None
from ddtrace.internal.telemetry.constants import TELEMETRY_LOG_LEVEL
key = (record.name, record.levelno, record.pathname, record.lineno)
current_bucket = int(record.created / _TelemetryConfig.TELEMETRY_HEARTBEAT_INTERVAL)
Expand All @@ -204,9 +207,19 @@ def _report_telemetry_log(self, record):
else TELEMETRY_LOG_LEVEL.DEBUG
)
from ddtrace.internal import telemetry
# TODO stack_trace = record.exc_info if "".join(format_exception(*record.exc_info)) else None
# TODO tags
telemetry.telemetry_writer.add_log(level, record.msg) # TODO stacktrace and tags
tags = {
"lib_language": "python",
}
stack_trace = None
if record.exc_info:
_, _, traceback_object = record.exc_info
if traceback_object:
stack_trace = ''.join(traceback.format_tb(traceback_object))
# TODO redact absolute file paths and unknown packages
if record.levelno >= logging.ERROR or stack_trace is not None:
# Report only an error or an exception with a stack trace
telemetry.telemetry_writer.add_log(level, record.msg, tags=tags, stack_trace=stack_trace)


class _TelemetryConfig:
TELEMETRY_ENABLED = os.getenv("DD_INSTRUMENTATION_TELEMETRY_ENABLED", "true").lower() in ("true", "1")
Expand Down

0 comments on commit ee669be

Please sign in to comment.