collector/service/main.go (61 lines of code) (raw):
// Copyright 2022 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package service
import (
"context"
"fmt"
"log"
"go.opentelemetry.io/collector/component"
"go.opentelemetry.io/collector/confmap"
"go.opentelemetry.io/collector/otelcol"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
"github.com/GoogleCloudPlatform/run-gmp-sidecar/collector/internal/env"
"github.com/GoogleCloudPlatform/run-gmp-sidecar/collector/internal/levelchanger"
"github.com/GoogleCloudPlatform/run-gmp-sidecar/collector/internal/version"
envprovider "go.opentelemetry.io/collector/confmap/provider/envprovider"
fileprovider "go.opentelemetry.io/collector/confmap/provider/fileprovider"
httpprovider "go.opentelemetry.io/collector/confmap/provider/httpprovider"
httpsprovider "go.opentelemetry.io/collector/confmap/provider/httpsprovider"
yamlprovider "go.opentelemetry.io/collector/confmap/provider/yamlprovider"
)
func MainContext(ctx context.Context) {
if err := env.Create(); err != nil {
log.Printf("failed to build environment variables for config: %v", err)
}
info := component.BuildInfo{
Command: "run-gmp-sidecar",
Description: "Google Cloud Run GMP Sidecar",
Version: version.Version,
}
params := otelcol.CollectorSettings{
Factories: components,
BuildInfo: info,
ConfigProviderSettings: otelcol.ConfigProviderSettings{
ResolverSettings: confmap.ResolverSettings{
ProviderFactories: []confmap.ProviderFactory{
fileprovider.NewFactory(),
envprovider.NewFactory(),
yamlprovider.NewFactory(),
httpprovider.NewFactory(),
httpsprovider.NewFactory(),
},
},
},
LoggingOptions: []zap.Option{
levelchanger.NewLevelChangerOption(
zapcore.ErrorLevel,
zapcore.DebugLevel,
// We would like the Error logs from this file to be logged at Debug instead.
// https://github.com/open-telemetry/opentelemetry-collector/blob/831373ae6c6959f6c9258ac585a2ec0ab19a074f/receiver/scraperhelper/scrapercontroller.go#L198
levelchanger.FilePathLevelChangeCondition("scrapercontroller.go")),
},
}
if err := run(ctx, params); err != nil {
log.Fatal(err)
}
}
func run(ctx context.Context, params otelcol.CollectorSettings) error {
cmd := otelcol.NewCommand(params)
err := cmd.ExecuteContext(ctx)
if err != nil {
return fmt.Errorf("application run finished with error: %w", err)
}
return nil
}