Skip to content

Commit

Permalink
🎨 Tracing: instrument logs and ensure traces are propagated through `…
Browse files Browse the repository at this point in the history
…asyncio.Queue`s (#6857)
  • Loading branch information
bisgaard-itis authored Dec 6, 2024
1 parent e05d046 commit 1f9c110
Show file tree
Hide file tree
Showing 47 changed files with 216 additions and 20 deletions.
4 changes: 4 additions & 0 deletions packages/aws-library/requirements/_base.txt
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,7 @@ opentelemetry-api==1.27.0
# opentelemetry-exporter-otlp-proto-http
# opentelemetry-instrumentation
# opentelemetry-instrumentation-botocore
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
# opentelemetry-propagator-aws-xray
Expand All @@ -160,10 +161,13 @@ opentelemetry-exporter-otlp-proto-http==1.27.0
opentelemetry-instrumentation==0.48b0
# via
# opentelemetry-instrumentation-botocore
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
opentelemetry-instrumentation-botocore==0.48b0
# via -r requirements/_base.in
opentelemetry-instrumentation-logging==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-redis==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-requests==0.48b0
Expand Down
1 change: 1 addition & 0 deletions packages/service-library/requirements/_base.in
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ opentelemetry-api
opentelemetry-exporter-otlp
opentelemetry-instrumentation-requests
opentelemetry-instrumentation-redis
opentelemetry-instrumentation-logging
opentelemetry-sdk
psutil
pydantic
Expand Down
4 changes: 4 additions & 0 deletions packages/service-library/requirements/_base.txt
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,7 @@ opentelemetry-api==1.27.0
# opentelemetry-exporter-otlp-proto-grpc
# opentelemetry-exporter-otlp-proto-http
# opentelemetry-instrumentation
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
# opentelemetry-sdk
Expand All @@ -117,8 +118,11 @@ opentelemetry-exporter-otlp-proto-http==1.27.0
# via opentelemetry-exporter-otlp
opentelemetry-instrumentation==0.48b0
# via
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
opentelemetry-instrumentation-logging==0.48b0
# via -r requirements/_base.in
opentelemetry-instrumentation-redis==0.48b0
# via -r requirements/_base.in
opentelemetry-instrumentation-requests==0.48b0
Expand Down
24 changes: 14 additions & 10 deletions packages/service-library/src/servicelib/async_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
from functools import wraps
from typing import TYPE_CHECKING, Any, Awaitable, Callable, Deque

from . import tracing
from .utils_profiling_middleware import dont_profile, is_profiling, profile_context

logger = logging.getLogger(__name__)
Expand Down Expand Up @@ -34,6 +35,7 @@ class Context:

@dataclass
class QueueElement:
tracing_context: tracing.TracingContext
do_profile: bool = False
input: Awaitable | None = None
output: Any | None = None
Expand Down Expand Up @@ -162,16 +164,17 @@ async def worker(in_q: Queue[QueueElement], out_q: Queue) -> None:
while True:
element = await in_q.get()
in_q.task_done()
# check if requested to shutdown
try:
do_profile = element.do_profile
awaitable = element.input
if awaitable is None:
break
with profile_context(do_profile):
result = await awaitable
except Exception as e: # pylint: disable=broad-except
result = e
with tracing.use_tracing_context(element.tracing_context):
# check if requested to shutdown
try:
do_profile = element.do_profile
awaitable = element.input
if awaitable is None:
break
with profile_context(do_profile):
result = await awaitable
except Exception as e: # pylint: disable=broad-except
result = e
await out_q.put(result)

logging.info(
Expand All @@ -189,6 +192,7 @@ async def worker(in_q: Queue[QueueElement], out_q: Queue) -> None:
queue_input = QueueElement(
input=decorated_function(*args, **kwargs),
do_profile=is_profiling(),
tracing_context=tracing.get_context(),
)
await context.in_queue.put(queue_input)
wrapped_result = await context.out_queue.get()
Expand Down
1 change: 0 additions & 1 deletion packages/service-library/src/servicelib/fastapi/tracing.py
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,6 @@ def setup_tracing(
):
_logger.warning("Skipping opentelemetry tracing setup")
return

# Set up the tracer provider
resource = Resource(attributes={"service.name": service_name})
trace.set_tracer_provider(TracerProvider(resource=resource))
Expand Down
26 changes: 25 additions & 1 deletion packages/service-library/src/servicelib/logging_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,10 @@
from pathlib import Path
from typing import Any, NotRequired, TypeAlias, TypedDict, TypeVar

from settings_library.tracing import TracingSettings

from .logging_utils_filtering import GeneralLogFilter, LoggerName, MessageSubstring
from .tracing import setup_log_tracing
from .utils_secrets import mask_sensitive_data

_logger = logging.getLogger(__name__)
Expand Down Expand Up @@ -121,20 +124,41 @@ def config_all_loggers(
*,
log_format_local_dev_enabled: bool,
logger_filter_mapping: dict[LoggerName, list[MessageSubstring]],
tracing_settings: TracingSettings | None,
) -> None:
"""
Applies common configuration to ALL registered loggers
"""
fmt = DEFAULT_FORMATTING
the_manager: logging.Manager = logging.Logger.manager
root_logger = logging.getLogger()

loggers = [root_logger] + [
logging.getLogger(name) for name in the_manager.loggerDict
]

fmt = DEFAULT_FORMATTING
if tracing_settings is not None:
fmt = (
"log_level=%(levelname)s "
"| log_timestamp=%(asctime)s "
"| log_source=%(name)s:%(funcName)s(%(lineno)d) "
"| log_uid=%(log_uid)s "
"| log_oec=%(log_oec)s"
"| log_trace_id=%(otelTraceID)s "
"| log_span_id=%(otelSpanID)s "
"| log_resource.service.name=%(otelServiceName)s "
"| log_trace_sampled=%(otelTraceSampled)s] "
"| log_msg=%(message)s"
)
setup_log_tracing(tracing_settings=tracing_settings)
if log_format_local_dev_enabled:
fmt = LOCAL_FORMATTING
if tracing_settings is not None:
fmt = (
"%(levelname)s: [%(asctime)s/%(processName)s] "
"[log_trace_id=%(otelTraceID)s log_span_id=%(otelSpanID)s log_resource.service.name=%(otelServiceName)s log_trace_sampled=%(otelTraceSampled)s] "
"[%(name)s:%(funcName)s(%(lineno)d)] - %(message)s"
)

for logger in loggers:
_set_logging_handler(
Expand Down
35 changes: 35 additions & 0 deletions packages/service-library/src/servicelib/tracing.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
from contextlib import contextmanager
from typing import TypeAlias

from opentelemetry import context as otcontext
from opentelemetry import trace
from opentelemetry.instrumentation.logging import LoggingInstrumentor
from settings_library.tracing import TracingSettings

TracingContext: TypeAlias = otcontext.Context | None


def _is_tracing() -> bool:
return trace.get_current_span().is_recording()


def get_context() -> TracingContext:
if not _is_tracing():
return None
return otcontext.get_current()


@contextmanager
def use_tracing_context(context: TracingContext):
if context is not None:
otcontext.attach(context)
try:
yield
finally:
if context is not None:
otcontext.detach(context)


def setup_log_tracing(tracing_settings: TracingSettings):
_ = tracing_settings
LoggingInstrumentor().instrument(set_logging_format=False)
4 changes: 4 additions & 0 deletions packages/simcore-sdk/requirements/_base.txt
Original file line number Diff line number Diff line change
Expand Up @@ -165,6 +165,7 @@ opentelemetry-api==1.27.0
# opentelemetry-instrumentation-aiopg
# opentelemetry-instrumentation-asyncpg
# opentelemetry-instrumentation-dbapi
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
# opentelemetry-sdk
Expand All @@ -184,6 +185,7 @@ opentelemetry-instrumentation==0.48b0
# opentelemetry-instrumentation-aiopg
# opentelemetry-instrumentation-asyncpg
# opentelemetry-instrumentation-dbapi
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
opentelemetry-instrumentation-aiopg==0.48b0
Expand All @@ -192,6 +194,8 @@ opentelemetry-instrumentation-asyncpg==0.48b0
# via -r requirements/../../../packages/postgres-database/requirements/_base.in
opentelemetry-instrumentation-dbapi==0.48b0
# via opentelemetry-instrumentation-aiopg
opentelemetry-instrumentation-logging==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-redis==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-requests==0.48b0
Expand Down
6 changes: 5 additions & 1 deletion services/agent/requirements/_base.txt
Original file line number Diff line number Diff line change
Expand Up @@ -157,6 +157,7 @@ opentelemetry-api==1.28.2
# opentelemetry-instrumentation-asgi
# opentelemetry-instrumentation-fastapi
# opentelemetry-instrumentation-httpx
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
# opentelemetry-sdk
Expand All @@ -176,6 +177,7 @@ opentelemetry-instrumentation==0.49b2
# opentelemetry-instrumentation-asgi
# opentelemetry-instrumentation-fastapi
# opentelemetry-instrumentation-httpx
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
opentelemetry-instrumentation-asgi==0.49b2
Expand All @@ -184,7 +186,9 @@ opentelemetry-instrumentation-fastapi==0.49b2
# via -r requirements/../../../packages/service-library/requirements/_fastapi.in
opentelemetry-instrumentation-httpx==0.49b2
# via -r requirements/../../../packages/service-library/requirements/_fastapi.in
opentelemetry-instrumentation-redis==0.49b2
opentelemetry-instrumentation-logging==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-redis==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-requests==0.49b2
# via -r requirements/../../../packages/service-library/requirements/_base.in
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ def _setup_logger(settings: ApplicationSettings):
config_all_loggers(
log_format_local_dev_enabled=settings.AGENT_VOLUMES_LOG_FORMAT_LOCAL_DEV_ENABLED,
logger_filter_mapping=settings.AGENT_VOLUMES_LOG_FILTER_MAPPING,
tracing_settings=settings.AGENT_TRACING,
)


Expand Down
6 changes: 6 additions & 0 deletions services/api-server/requirements/_base.txt
Original file line number Diff line number Diff line change
Expand Up @@ -357,6 +357,7 @@ opentelemetry-api==1.27.0
# opentelemetry-instrumentation-dbapi
# opentelemetry-instrumentation-fastapi
# opentelemetry-instrumentation-httpx
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
# opentelemetry-sdk
Expand All @@ -381,6 +382,7 @@ opentelemetry-instrumentation==0.48b0
# opentelemetry-instrumentation-dbapi
# opentelemetry-instrumentation-fastapi
# opentelemetry-instrumentation-httpx
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
opentelemetry-instrumentation-aiopg==0.48b0
Expand All @@ -397,6 +399,10 @@ opentelemetry-instrumentation-fastapi==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_fastapi.in
opentelemetry-instrumentation-httpx==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_fastapi.in
opentelemetry-instrumentation-logging==0.48b0
# via
# -r requirements/../../../packages/service-library/requirements/_base.in
# -r requirements/../../../packages/simcore-sdk/requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-redis==0.48b0
# via
# -r requirements/../../../packages/service-library/requirements/_base.in
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ def init_app(settings: ApplicationSettings | None = None) -> FastAPI:
config_all_loggers(
log_format_local_dev_enabled=settings.API_SERVER_LOG_FORMAT_LOCAL_DEV_ENABLED,
logger_filter_mapping=settings.API_SERVER_LOG_FILTER_MAPPING,
tracing_settings=settings.API_SERVER_TRACING,
)
_logger.debug("App settings:\n%s", settings.model_dump_json(indent=2))

Expand Down
6 changes: 6 additions & 0 deletions services/autoscaling/requirements/_base.txt
Original file line number Diff line number Diff line change
Expand Up @@ -297,6 +297,7 @@ opentelemetry-api==1.26.0
# opentelemetry-instrumentation-botocore
# opentelemetry-instrumentation-fastapi
# opentelemetry-instrumentation-httpx
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
# opentelemetry-propagator-aws-xray
Expand All @@ -320,6 +321,7 @@ opentelemetry-instrumentation==0.47b0
# opentelemetry-instrumentation-botocore
# opentelemetry-instrumentation-fastapi
# opentelemetry-instrumentation-httpx
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
opentelemetry-instrumentation-asgi==0.47b0
Expand All @@ -330,6 +332,10 @@ opentelemetry-instrumentation-fastapi==0.47b0
# via -r requirements/../../../packages/service-library/requirements/_fastapi.in
opentelemetry-instrumentation-httpx==0.47b0
# via -r requirements/../../../packages/service-library/requirements/_fastapi.in
opentelemetry-instrumentation-logging==0.47b0
# via
# -r requirements/../../../packages/aws-library/requirements/../../../packages/service-library/requirements/_base.in
# -r requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-redis==0.47b0
# via
# -r requirements/../../../packages/aws-library/requirements/../../../packages/service-library/requirements/_base.in
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
config_all_loggers(
log_format_local_dev_enabled=the_settings.AUTOSCALING_LOG_FORMAT_LOCAL_DEV_ENABLED,
logger_filter_mapping=the_settings.AUTOSCALING_LOG_FILTER_MAPPING,
tracing_settings=the_settings.AUTOSCALING_TRACING,
)

# SINGLETON FastAPI app
Expand Down
4 changes: 4 additions & 0 deletions services/catalog/requirements/_base.txt
Original file line number Diff line number Diff line change
Expand Up @@ -222,6 +222,7 @@ opentelemetry-api==1.27.0
# opentelemetry-instrumentation-asyncpg
# opentelemetry-instrumentation-fastapi
# opentelemetry-instrumentation-httpx
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
# opentelemetry-sdk
Expand All @@ -242,6 +243,7 @@ opentelemetry-instrumentation==0.48b0
# opentelemetry-instrumentation-asyncpg
# opentelemetry-instrumentation-fastapi
# opentelemetry-instrumentation-httpx
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
opentelemetry-instrumentation-asgi==0.48b0
Expand All @@ -252,6 +254,8 @@ opentelemetry-instrumentation-fastapi==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_fastapi.in
opentelemetry-instrumentation-httpx==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_fastapi.in
opentelemetry-instrumentation-logging==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-redis==0.48b0
# via -r requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-requests==0.48b0
Expand Down
1 change: 1 addition & 0 deletions services/catalog/src/simcore_service_catalog/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
config_all_loggers(
log_format_local_dev_enabled=_the_settings.CATALOG_LOG_FORMAT_LOCAL_DEV_ENABLED,
logger_filter_mapping=_the_settings.CATALOG_LOG_FILTER_MAPPING,
tracing_settings=_the_settings.CATALOG_TRACING,
)


Expand Down
6 changes: 6 additions & 0 deletions services/clusters-keeper/requirements/_base.txt
Original file line number Diff line number Diff line change
Expand Up @@ -295,6 +295,7 @@ opentelemetry-api==1.26.0
# opentelemetry-instrumentation-botocore
# opentelemetry-instrumentation-fastapi
# opentelemetry-instrumentation-httpx
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
# opentelemetry-propagator-aws-xray
Expand All @@ -318,6 +319,7 @@ opentelemetry-instrumentation==0.47b0
# opentelemetry-instrumentation-botocore
# opentelemetry-instrumentation-fastapi
# opentelemetry-instrumentation-httpx
# opentelemetry-instrumentation-logging
# opentelemetry-instrumentation-redis
# opentelemetry-instrumentation-requests
opentelemetry-instrumentation-asgi==0.47b0
Expand All @@ -328,6 +330,10 @@ opentelemetry-instrumentation-fastapi==0.47b0
# via -r requirements/../../../packages/service-library/requirements/_fastapi.in
opentelemetry-instrumentation-httpx==0.47b0
# via -r requirements/../../../packages/service-library/requirements/_fastapi.in
opentelemetry-instrumentation-logging==0.47b0
# via
# -r requirements/../../../packages/aws-library/requirements/../../../packages/service-library/requirements/_base.in
# -r requirements/../../../packages/service-library/requirements/_base.in
opentelemetry-instrumentation-redis==0.47b0
# via
# -r requirements/../../../packages/aws-library/requirements/../../../packages/service-library/requirements/_base.in
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
config_all_loggers(
log_format_local_dev_enabled=the_settings.CLUSTERS_KEEPER_LOG_FORMAT_LOCAL_DEV_ENABLED,
logger_filter_mapping=the_settings.CLUSTERS_KEEPER_LOG_FILTER_MAPPING,
tracing_settings=the_settings.CLUSTERS_KEEPER_TRACING,
)

# SINGLETON FastAPI app
Expand Down
Loading

0 comments on commit 1f9c110

Please sign in to comment.