From 5f506a9b9bf1b01b47db0c610a2539d05825aacc Mon Sep 17 00:00:00 2001 From: Pablo Baeyens Date: Fri, 15 Jul 2022 16:13:58 +0200 Subject: [PATCH] [exporter/logging] Create logging exporter logger from service logger (#5677) Build the logger on the logging exporter's logger from the one on `TelemetrySettings`, so that the logger honors the configuration settings on `telemetry::logs` and the configuration options on `CollectorSettings.LoggingOptions`. Depends on #5678 **Link to tracking Issue:** Fixes #5652 **Documentation:** Documented the feature gate. --- CHANGELOG.md | 1 + exporter/loggingexporter/factory.go | 44 ++++++++--------------------- 2 files changed, 13 insertions(+), 32 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 6d4a3bade2d..00caf6ec5df 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,7 @@ - `client`: perform case insensitive lookups in case the requested metadata value isn't found (#5646) - `loggingexporter`: Decouple `loglevel` field from level of logged messages (#5678) - Expose `pcommon.NewSliceFromRaw` function (#5679) +- `loggingexporter`: create the exporter's logger from the service's logger (#5677) ### 🧰 Bug fixes 🧰 diff --git a/exporter/loggingexporter/factory.go b/exporter/loggingexporter/factory.go index 4dc64da9d68..dca2659ebf9 100644 --- a/exporter/loggingexporter/factory.go +++ b/exporter/loggingexporter/factory.go @@ -16,6 +16,7 @@ package loggingexporter // import "go.opentelemetry.io/collector/exporter/loggin import ( "context" + "time" "go.uber.org/zap" "go.uber.org/zap/zapcore" @@ -53,50 +54,29 @@ func createDefaultConfig() config.Exporter { func createTracesExporter(_ context.Context, set component.ExporterCreateSettings, config config.Exporter) (component.TracesExporter, error) { cfg := config.(*Config) - - exporterLogger, err := createLogger(cfg) - if err != nil { - return nil, err - } - + exporterLogger := createLogger(cfg, set.TelemetrySettings.Logger) return newTracesExporter(cfg, exporterLogger, set) } func createMetricsExporter(_ context.Context, set component.ExporterCreateSettings, config config.Exporter) (component.MetricsExporter, error) { cfg := config.(*Config) - - exporterLogger, err := createLogger(cfg) - if err != nil { - return nil, err - } - + exporterLogger := createLogger(cfg, set.TelemetrySettings.Logger) return newMetricsExporter(cfg, exporterLogger, set) } func createLogsExporter(_ context.Context, set component.ExporterCreateSettings, config config.Exporter) (component.LogsExporter, error) { cfg := config.(*Config) - - exporterLogger, err := createLogger(cfg) - if err != nil { - return nil, err - } - + exporterLogger := createLogger(cfg, set.TelemetrySettings.Logger) return newLogsExporter(cfg, exporterLogger, set) } -func createLogger(cfg *Config) (*zap.Logger, error) { - // We take development config as the base since it matches the purpose - // of logging exporter being used for debugging reasons (so e.g. console encoder) - conf := zap.NewDevelopmentConfig() - conf.Level = zap.NewAtomicLevelAt(cfg.LogLevel) - conf.Sampling = &zap.SamplingConfig{ - Initial: cfg.SamplingInitial, - Thereafter: cfg.SamplingThereafter, - } +func createLogger(cfg *Config, logger *zap.Logger) *zap.Logger { + core := zapcore.NewSamplerWithOptions( + logger.Core(), + 1*time.Second, + cfg.SamplingInitial, + cfg.SamplingThereafter, + ) - logginglogger, err := conf.Build() - if err != nil { - return nil, err - } - return logginglogger, nil + return zap.New(core) }