otel-utils 0.1.20__tar.gz → 0.2.0__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of otel-utils might be problematic. Click here for more details.
- {otel_utils-0.1.20 → otel_utils-0.2.0}/PKG-INFO +1 -1
- {otel_utils-0.1.20 → otel_utils-0.2.0}/pyproject.toml +1 -1
- {otel_utils-0.1.20 → otel_utils-0.2.0}/src/otel_utils/configurator.py +11 -0
- {otel_utils-0.1.20 → otel_utils-0.2.0}/src/otel_utils/logging.py +7 -3
- {otel_utils-0.1.20 → otel_utils-0.2.0}/README.md +0 -0
- {otel_utils-0.1.20 → otel_utils-0.2.0}/src/otel_utils/__init__.py +0 -0
- {otel_utils-0.1.20 → otel_utils-0.2.0}/src/otel_utils/metrics.py +0 -0
- {otel_utils-0.1.20 → otel_utils-0.2.0}/src/otel_utils/tracing.py +0 -0
|
@@ -133,6 +133,11 @@ class OtelConfigurator:
|
|
|
133
133
|
for handler in service_logger.handlers[:]:
|
|
134
134
|
service_logger.removeHandler(handler)
|
|
135
135
|
|
|
136
|
+
for logger_name in logging.root.manager.loggerDict:
|
|
137
|
+
logger = logging.getLogger(logger_name)
|
|
138
|
+
for handler in logger.handlers[:]:
|
|
139
|
+
logger.removeHandler(handler)
|
|
140
|
+
|
|
136
141
|
logging.getLogger('opentelemetry').setLevel(logging.ERROR)
|
|
137
142
|
|
|
138
143
|
logger_provider = LoggerProvider(resource=self.resource)
|
|
@@ -156,9 +161,13 @@ class OtelConfigurator:
|
|
|
156
161
|
)
|
|
157
162
|
|
|
158
163
|
console_handler.setFormatter(formatter)
|
|
164
|
+
|
|
159
165
|
root_logger.addHandler(console_handler)
|
|
160
166
|
root_logger.setLevel(self.config.log_level)
|
|
161
167
|
|
|
168
|
+
service_logger.propagate = True
|
|
169
|
+
service_logger.handlers = []
|
|
170
|
+
|
|
162
171
|
LoggingInstrumentor().instrument(
|
|
163
172
|
logger_provider=logger_provider,
|
|
164
173
|
set_logging_format=False,
|
|
@@ -170,6 +179,8 @@ class OtelConfigurator:
|
|
|
170
179
|
self.structured_logger = StructuredLogger(self.config.service_name)
|
|
171
180
|
self.logger = self.structured_logger.logger
|
|
172
181
|
|
|
182
|
+
self.logger.propagate = False
|
|
183
|
+
|
|
173
184
|
|
|
174
185
|
def get_logger(service_name: str = None, config: OtelConfig = None) -> StructuredLogger:
|
|
175
186
|
if config:
|
|
@@ -8,9 +8,8 @@ from opentelemetry import trace
|
|
|
8
8
|
|
|
9
9
|
|
|
10
10
|
class JsonFormatter(logging.Formatter):
|
|
11
|
-
|
|
12
11
|
def format(self, record):
|
|
13
|
-
log_record = {"timestamp": datetime.utcnow().isoformat(), "level": record.levelname, "
|
|
12
|
+
log_record = {"timestamp": datetime.utcnow().isoformat(), "level": record.levelname, "service": record.name,
|
|
14
13
|
"message": record.getMessage()}
|
|
15
14
|
|
|
16
15
|
ignored_attrs = {
|
|
@@ -18,7 +17,8 @@ class JsonFormatter(logging.Formatter):
|
|
|
18
17
|
'levelno', 'pathname', 'filename', 'module', 'stack_info',
|
|
19
18
|
'lineno', 'funcName', 'created', 'msecs', 'relativeCreated',
|
|
20
19
|
'name', 'thread', 'threadName', 'processName', 'process',
|
|
21
|
-
'levelname', 'getMessage'
|
|
20
|
+
'levelname', 'getMessage',
|
|
21
|
+
'otelTraceID', 'otelSpanID', 'otelTraceSampled', 'otelServiceName'
|
|
22
22
|
}
|
|
23
23
|
|
|
24
24
|
if hasattr(record, "otelTraceID"):
|
|
@@ -30,6 +30,8 @@ class JsonFormatter(logging.Formatter):
|
|
|
30
30
|
if key not in ignored_attrs and not key.startswith('_'):
|
|
31
31
|
if key == 'context' and value:
|
|
32
32
|
log_record[key] = value
|
|
33
|
+
elif key == 'service_name' and 'service' in log_record and log_record['service'] == value:
|
|
34
|
+
pass
|
|
33
35
|
elif value is not None and value != '':
|
|
34
36
|
log_record[key] = value
|
|
35
37
|
|
|
@@ -50,6 +52,8 @@ class StructuredLogger:
|
|
|
50
52
|
self.service_name = service_name
|
|
51
53
|
self.default_attributes = default_attributes or {}
|
|
52
54
|
|
|
55
|
+
self.logger.propagate = False
|
|
56
|
+
|
|
53
57
|
if not self.logger.handlers:
|
|
54
58
|
handler = logging.StreamHandler()
|
|
55
59
|
handler.setFormatter(JsonFormatter())
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|