forked from epam/ai-dial
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: supported otlp export for metrics and logs (epam#88)
- Loading branch information
Showing
3 changed files
with
87 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,18 +1,50 @@ | ||
import logging | ||
import os | ||
from typing import Optional | ||
|
||
from aidial_sdk.pydantic_v1 import BaseModel | ||
from aidial_sdk.utils.env import env_var_list | ||
|
||
# OpenTelemetry SDK configuration env vars: | ||
# https://opentelemetry.io/docs/specs/otel/configuration/sdk-environment-variables/ | ||
|
||
OTEL_LOGS_EXPORTER = env_var_list("OTEL_LOGS_EXPORTER") | ||
OTEL_TRACES_EXPORTER = env_var_list("OTEL_TRACES_EXPORTER") | ||
OTEL_METRICS_EXPORTER = env_var_list("OTEL_METRICS_EXPORTER") | ||
OTEL_EXPORTER_PROMETHEUS_PORT = int( | ||
os.getenv("OTEL_EXPORTER_PROMETHEUS_PORT", 9464) | ||
) | ||
OTEL_PYTHON_LOG_CORRELATION = ( | ||
os.getenv("OTEL_PYTHON_LOG_CORRELATION", "false").lower() == "true" | ||
) | ||
|
||
|
||
class LogsConfig(BaseModel): | ||
otlp_export: bool = "otlp" in OTEL_LOGS_EXPORTER | ||
level: int = logging.INFO | ||
|
||
|
||
class TracingConfig(BaseModel): | ||
otlp_export: bool = False | ||
logging: bool = False | ||
otlp_export: bool = "otlp" in OTEL_TRACES_EXPORTER | ||
|
||
"""Configure logging to include tracing context | ||
into console log messages""" | ||
logging: bool = OTEL_PYTHON_LOG_CORRELATION | ||
|
||
|
||
class MetricsConfig(BaseModel): | ||
port: int = 9464 | ||
otlp_export: bool = "otlp" in OTEL_METRICS_EXPORTER | ||
prometheus_export: bool = "prometheus" in OTEL_METRICS_EXPORTER | ||
port: int = OTEL_EXPORTER_PROMETHEUS_PORT | ||
|
||
|
||
class TelemetryConfig(BaseModel): | ||
service_name: Optional[str] = None | ||
tracing: Optional[TracingConfig] = None | ||
metrics: Optional[MetricsConfig] = None | ||
|
||
logs: Optional[LogsConfig] = LogsConfig() if OTEL_LOGS_EXPORTER else None | ||
tracing: Optional[TracingConfig] = ( | ||
TracingConfig() if OTEL_TRACES_EXPORTER else None | ||
) | ||
metrics: Optional[MetricsConfig] = ( | ||
MetricsConfig() if OTEL_METRICS_EXPORTER else None | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
import os | ||
from typing import List | ||
|
||
|
||
def env_var_list(name: str) -> List[str]: | ||
value = os.getenv(name) | ||
if value is None: | ||
return [] | ||
return value.split(",") |