123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- // Copyright The OpenTelemetry Authors
- // SPDX-License-Identifier: Apache-2.0
- //go:generate mdatagen metadata.yaml
- package googlecloudexporter // import "github.com/open-telemetry/opentelemetry-collector-contrib/exporter/googlecloudexporter"
- import (
- "context"
- "time"
- "github.com/GoogleCloudPlatform/opentelemetry-operations-go/exporter/collector"
- "go.opentelemetry.io/collector/component"
- "go.opentelemetry.io/collector/exporter"
- "go.opentelemetry.io/collector/exporter/exporterhelper"
- "go.opentelemetry.io/collector/featuregate"
- "github.com/open-telemetry/opentelemetry-collector-contrib/exporter/googlecloudexporter/internal/metadata"
- )
- const (
- defaultTimeout = 12 * time.Second // Consistent with Cloud Monitoring's timeout
- )
- var _ = featuregate.GlobalRegistry().MustRegister(
- "exporter.googlecloud.OTLPDirect",
- featuregate.StageStable,
- featuregate.WithRegisterDescription("When enabled, the googlecloud exporter translates pdata directly to google cloud monitoring's types, rather than first translating to opencensus."),
- featuregate.WithRegisterReferenceURL("https://github.com/open-telemetry/opentelemetry-collector-contrib/issues/7132"),
- featuregate.WithRegisterToVersion("v0.69.0"),
- )
- // NewFactory creates a factory for the googlecloud exporter
- func NewFactory() exporter.Factory {
- return exporter.NewFactory(
- metadata.Type,
- createDefaultConfig,
- exporter.WithTraces(createTracesExporter, metadata.TracesStability),
- exporter.WithMetrics(createMetricsExporter, metadata.MetricsStability),
- exporter.WithLogs(createLogsExporter, metadata.LogsStability),
- )
- }
- // createDefaultConfig creates the default configuration for exporter.
- func createDefaultConfig() component.Config {
- return &Config{
- TimeoutSettings: exporterhelper.TimeoutSettings{Timeout: defaultTimeout},
- QueueSettings: exporterhelper.NewDefaultQueueSettings(),
- Config: collector.DefaultConfig(),
- }
- }
- func createLogsExporter(
- ctx context.Context,
- params exporter.CreateSettings,
- cfg component.Config) (exporter.Logs, error) {
- eCfg := cfg.(*Config)
- logsExporter, err := collector.NewGoogleCloudLogsExporter(ctx, eCfg.Config, params.TelemetrySettings.Logger, params.BuildInfo.Version)
- if err != nil {
- return nil, err
- }
- return exporterhelper.NewLogsExporter(
- ctx,
- params,
- cfg,
- logsExporter.PushLogs,
- exporterhelper.WithShutdown(logsExporter.Shutdown),
- // Disable exporterhelper Timeout, since we are using a custom mechanism
- // within exporter itself
- exporterhelper.WithTimeout(exporterhelper.TimeoutSettings{Timeout: 0}),
- exporterhelper.WithQueue(eCfg.QueueSettings))
- }
- // createTracesExporter creates a trace exporter based on this config.
- func createTracesExporter(
- ctx context.Context,
- params exporter.CreateSettings,
- cfg component.Config) (exporter.Traces, error) {
- eCfg := cfg.(*Config)
- tExp, err := collector.NewGoogleCloudTracesExporter(ctx, eCfg.Config, params.BuildInfo.Version, eCfg.Timeout)
- if err != nil {
- return nil, err
- }
- return exporterhelper.NewTracesExporter(
- ctx,
- params,
- cfg,
- tExp.PushTraces,
- exporterhelper.WithShutdown(tExp.Shutdown),
- // Disable exporterhelper Timeout, since we are using a custom mechanism
- // within exporter itself
- exporterhelper.WithTimeout(exporterhelper.TimeoutSettings{Timeout: 0}),
- exporterhelper.WithQueue(eCfg.QueueSettings))
- }
- // createMetricsExporter creates a metrics exporter based on this config.
- func createMetricsExporter(
- ctx context.Context,
- params exporter.CreateSettings,
- cfg component.Config) (exporter.Metrics, error) {
- eCfg := cfg.(*Config)
- mExp, err := collector.NewGoogleCloudMetricsExporter(ctx, eCfg.Config, params.TelemetrySettings.Logger, params.BuildInfo.Version, eCfg.Timeout)
- if err != nil {
- return nil, err
- }
- return exporterhelper.NewMetricsExporter(
- ctx,
- params,
- cfg,
- mExp.PushMetrics,
- exporterhelper.WithShutdown(mExp.Shutdown),
- // Disable exporterhelper Timeout, since we are using a custom mechanism
- // within exporter itself
- exporterhelper.WithTimeout(exporterhelper.TimeoutSettings{Timeout: 0}),
- exporterhelper.WithQueue(eCfg.QueueSettings))
- }
|