Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
aos
GitHub Repository: aos/grafana-agent
Path: blob/main/component/otelcol/receiver/prometheus/internal/appendable.go
5365 views
1
// Copyright The OpenTelemetry Authors
2
//
3
// Licensed under the Apache License, Version 2.0 (the "License");
4
// you may not use this file except in compliance with the License.
5
// You may obtain a copy of the License at
6
//
7
// http://www.apache.org/licenses/LICENSE-2.0
8
//
9
// Unless required by applicable law or agreed to in writing, software
10
// distributed under the License is distributed on an "AS IS" BASIS,
11
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
// See the License for the specific language governing permissions and
13
// limitations under the License.
14
15
package internal // import "github.com/open-telemetry/opentelemetry-collector-contrib/receiver/prometheusreceiver/internal"
16
17
import (
18
"context"
19
"regexp"
20
"time"
21
22
"github.com/prometheus/prometheus/model/labels"
23
"github.com/prometheus/prometheus/storage"
24
"go.opentelemetry.io/collector/component"
25
"go.opentelemetry.io/collector/config"
26
"go.opentelemetry.io/collector/consumer"
27
"go.opentelemetry.io/collector/obsreport"
28
)
29
30
// appendable translates Prometheus scraping diffs into OpenTelemetry format.
31
type appendable struct {
32
sink consumer.Metrics
33
metricAdjuster MetricsAdjuster
34
useStartTimeMetric bool
35
startTimeMetricRegex *regexp.Regexp
36
externalLabels labels.Labels
37
38
settings component.ReceiverCreateSettings
39
obsrecv *obsreport.Receiver
40
}
41
42
// NewAppendable returns a storage.Appendable instance that emits metrics to the sink.
43
func NewAppendable(
44
sink consumer.Metrics,
45
set component.ReceiverCreateSettings,
46
gcInterval time.Duration,
47
useStartTimeMetric bool,
48
startTimeMetricRegex *regexp.Regexp,
49
receiverID config.ComponentID,
50
externalLabels labels.Labels) storage.Appendable {
51
52
var metricAdjuster MetricsAdjuster
53
if !useStartTimeMetric {
54
metricAdjuster = NewInitialPointAdjuster(set.Logger, gcInterval)
55
} else {
56
metricAdjuster = NewStartTimeMetricAdjuster(set.Logger, startTimeMetricRegex)
57
}
58
59
return &appendable{
60
sink: sink,
61
settings: set,
62
metricAdjuster: metricAdjuster,
63
useStartTimeMetric: useStartTimeMetric,
64
startTimeMetricRegex: startTimeMetricRegex,
65
externalLabels: externalLabels,
66
obsrecv: obsreport.NewReceiver(obsreport.ReceiverSettings{ReceiverID: receiverID, Transport: transport, ReceiverCreateSettings: set}),
67
}
68
}
69
70
func (o *appendable) Appender(ctx context.Context) storage.Appender {
71
return newTransaction(ctx, o.metricAdjuster, o.sink, o.externalLabels, o.settings, o.obsrecv)
72
}
73
74