-
Notifications
You must be signed in to change notification settings - Fork 480
/
otlp.go
101 lines (83 loc) · 3.25 KB
/
otlp.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
// Package otlp provides an otelcol.exporter.otlp component.
package otlp
import (
"time"
"github.com/grafana/agent/component"
"github.com/grafana/agent/component/otelcol"
"github.com/grafana/agent/component/otelcol/exporter"
otelcomponent "go.opentelemetry.io/collector/component"
otelpexporterhelper "go.opentelemetry.io/collector/exporter/exporterhelper"
"go.opentelemetry.io/collector/exporter/otlpexporter"
otelextension "go.opentelemetry.io/collector/extension"
)
func init() {
component.Register(component.Registration{
Name: "otelcol.exporter.otlp",
Args: Arguments{},
Exports: otelcol.ConsumerExports{},
Build: func(opts component.Options, args component.Arguments) (component.Component, error) {
fact := otlpexporter.NewFactory()
return exporter.New(opts, fact, args.(Arguments), exporter.TypeAll)
},
})
}
// Arguments configures the otelcol.exporter.otlp component.
type Arguments struct {
Timeout time.Duration `river:"timeout,attr,optional"`
Queue otelcol.QueueArguments `river:"sending_queue,block,optional"`
Retry otelcol.RetryArguments `river:"retry_on_failure,block,optional"`
// DebugMetrics configures component internal metrics. Optional.
DebugMetrics otelcol.DebugMetricsArguments `river:"debug_metrics,block,optional"`
Client GRPCClientArguments `river:"client,block"`
}
var _ exporter.Arguments = Arguments{}
// DefaultArguments holds default values for Arguments.
var DefaultArguments = Arguments{
Timeout: otelcol.DefaultTimeout,
Queue: otelcol.DefaultQueueArguments,
Retry: otelcol.DefaultRetryArguments,
Client: DefaultGRPCClientArguments,
DebugMetrics: otelcol.DefaultDebugMetricsArguments,
}
// SetToDefault implements river.Defaulter.
func (args *Arguments) SetToDefault() {
*args = DefaultArguments
}
// Convert implements exporter.Arguments.
func (args Arguments) Convert() (otelcomponent.Config, error) {
return &otlpexporter.Config{
TimeoutSettings: otelpexporterhelper.TimeoutSettings{
Timeout: args.Timeout,
},
QueueSettings: *args.Queue.Convert(),
RetrySettings: *args.Retry.Convert(),
GRPCClientSettings: *(*otelcol.GRPCClientArguments)(&args.Client).Convert(),
}, nil
}
// Extensions implements exporter.Arguments.
func (args Arguments) Extensions() map[otelcomponent.ID]otelextension.Extension {
return (*otelcol.GRPCClientArguments)(&args.Client).Extensions()
}
// Exporters implements exporter.Arguments.
func (args Arguments) Exporters() map[otelcomponent.DataType]map[otelcomponent.ID]otelcomponent.Component {
return nil
}
// DebugMetricsConfig implements receiver.Arguments.
func (args Arguments) DebugMetricsConfig() otelcol.DebugMetricsArguments {
return args.DebugMetrics
}
// GRPCClientArguments is used to configure otelcol.exporter.otlp with
// component-specific defaults.
type GRPCClientArguments otelcol.GRPCClientArguments
// DefaultGRPCClientArguments holds component-specific default settings for
// GRPCClientArguments.
var DefaultGRPCClientArguments = GRPCClientArguments{
Headers: map[string]string{},
Compression: otelcol.CompressionTypeGzip,
WriteBufferSize: 512 * 1024,
BalancerName: "pick_first",
}
// SetToDefault implements river.Defaulter.
func (args *GRPCClientArguments) SetToDefault() {
*args = DefaultGRPCClientArguments
}