Documentation ¶
Overview ¶
Package service handles the command-line, configuration, and runs the OpenTelemetry Collector.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func NewCommand ¶ added in v0.36.0
func NewCommand(set CollectorSettings) *cobra.Command
NewCommand constructs a new cobra.Command using the given CollectorSettings.
Types ¶
type Collector ¶ added in v0.29.0
type Collector struct {
// contains filtered or unexported fields
}
Collector represents a server providing the OpenTelemetry Collector service. Deprecated: [v0.67.0] use otelcol.Collector
func New ¶
func New(set CollectorSettings) (*Collector, error)
New creates and returns a new instance of Collector. Deprecated: [v0.67.0] use otelcol.NewCollector
func (*Collector) GetState ¶ added in v0.40.0
GetState returns current state of the collector server.
type CollectorSettings ¶ added in v0.29.0
type CollectorSettings struct { // Factories component factories. Factories component.Factories // BuildInfo provides collector start information. BuildInfo component.BuildInfo // DisableGracefulShutdown disables the automatic graceful shutdown // of the collector on SIGINT or SIGTERM. // Users who want to handle signals themselves can disable this behavior // and manually handle the signals to shutdown the collector. DisableGracefulShutdown bool // ConfigProvider provides the service configuration. // If the provider watches for configuration change, collector may reload the new configuration upon changes. ConfigProvider ConfigProvider // LoggingOptions provides a way to change behavior of zap logging. LoggingOptions []zap.Option // SkipSettingGRPCLogger avoids setting the grpc logger SkipSettingGRPCLogger bool // contains filtered or unexported fields }
CollectorSettings holds configuration for creating a new Collector. Deprecated: [v0.66.0] use otelcol.CollectorSettings.
type Config
deprecated
added in
v0.52.0
type Config struct { // Receivers is a map of ComponentID to Receivers. Receivers map[component.ID]component.Config // Exporters is a map of ComponentID to Exporters. Exporters map[component.ID]component.Config // Processors is a map of ComponentID to Processors. Processors map[component.ID]component.Config // Extensions is a map of ComponentID to extensions. Extensions map[component.ID]component.Config Service ConfigService }
Deprecated: [v0.67.0] use otelcol.Config
func (*Config) Validate ¶ added in v0.64.0
Validate returns an error if the config is invalid.
This function performs basic validation of configuration. There may be more subtle invalid cases that we currently don't check for but which we may want to add in the future (e.g. disallowing receiving and exporting on the same endpoint).
type ConfigProvider
deprecated
added in
v0.42.0
type ConfigProvider interface { // Get returns the service configuration, or error otherwise. // // Should never be called concurrently with itself, Watch or Shutdown. Get(ctx context.Context, factories component.Factories) (*Config, error) // Watch blocks until any configuration change was detected or an unrecoverable error // happened during monitoring the configuration changes. // // Error is nil if the configuration is changed and needs to be re-fetched. Any non-nil // error indicates that there was a problem with watching the config changes. // // Should never be called concurrently with itself or Get. Watch() <-chan error // Shutdown signals that the provider is no longer in use and the that should close // and release any resources that it may have created. // // This function must terminate the Watch channel. // // Should never be called concurrently with itself or Get. Shutdown(ctx context.Context) error }
ConfigProvider provides the service configuration.
The typical usage is the following:
cfgProvider.Get(...) cfgProvider.Watch() // wait for an event. cfgProvider.Get(...) cfgProvider.Watch() // wait for an event. // repeat Get/Watch cycle until it is time to shut down the Collector process. cfgProvider.Shutdown()
Deprecated: [v0.67.0] use otelcol.ConfigProvider
func NewConfigProvider ¶ added in v0.42.0
func NewConfigProvider(set ConfigProviderSettings) (ConfigProvider, error)
NewConfigProvider returns a new ConfigProvider that provides the service configuration: * Initially it resolves the "configuration map":
- Retrieve the confmap.Conf by merging all retrieved maps from the given `locations` in order.
- Then applies all the confmap.Converter in the given order.
* Then unmarshalls the confmap.Conf into the service Config. Deprecated: [v0.67.0] use otelcol.NewConfigProvider
type ConfigProviderSettings ¶ added in v0.49.0
type ConfigProviderSettings struct { // ResolverSettings are the settings to configure the behavior of the confmap.Resolver. ResolverSettings confmap.ResolverSettings }
ConfigProviderSettings are the settings to configure the behavior of the ConfigProvider. Deprecated: [v0.67.0] use otelcol.ConfigProviderSettings
type ConfigService ¶ added in v0.52.0
type ConfigService struct { // Telemetry is the configuration for collector's own telemetry. Telemetry telemetry.Config `mapstructure:"telemetry"` // Extensions are the ordered list of extensions configured for the service. Extensions []component.ID `mapstructure:"extensions"` // Pipelines are the set of data pipelines configured for the service. Pipelines map[component.ID]*ConfigServicePipeline `mapstructure:"pipelines"` }
ConfigService defines the configurable components of the service.
func (*ConfigService) Validate ¶ added in v0.67.0
func (cfg *ConfigService) Validate() error
type ConfigServicePipeline ¶ added in v0.52.0
type ConfigServicePipeline struct { Receivers []component.ID `mapstructure:"receivers"` Processors []component.ID `mapstructure:"processors"` Exporters []component.ID `mapstructure:"exporters"` }
func (*ConfigServicePipeline) Validate ¶ added in v0.67.0
func (cfg *ConfigServicePipeline) Validate() error
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
internal
|
|
fanoutconsumer
Package fanoutconsumer contains implementations of Traces/Metrics/Logs consumers that fan out the data to multiple other consumers.
|
Package fanoutconsumer contains implementations of Traces/Metrics/Logs consumers that fan out the data to multiple other consumers. |