Skip to content

Commit 3547d76

Browse files
committed
Deprecate blocking in favor of block_on_overflow
Signed-off-by: Bogdan Drutu <[email protected]>
1 parent 58370e5 commit 3547d76

File tree

11 files changed

+169
-16
lines changed

11 files changed

+169
-16
lines changed

.chloggen/deprecate-blocking.yaml

+25
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
# Use this changelog template to create an entry for release notes.
2+
3+
# One of 'breaking', 'deprecation', 'new_component', 'enhancement', 'bug_fix'
4+
change_type: deprecation
5+
6+
# The name of the component, or a single word describing the area of concern, (e.g. otlpreceiver)
7+
component: exporterhelper
8+
9+
# A brief description of the change. Surround your text with quotes ("") if it needs to start with a backtick (`).
10+
note: Deprecate `blocking` in favor of `block_on_overflow`.
11+
12+
# One or more tracking issues or pull requests related to the change
13+
issues: [12710]
14+
15+
# (Optional) One or more lines of additional information to render under the primary note.
16+
# These lines will be padded with 2 spaces and then inserted directly into the document.
17+
# Use pipe (|) for multiline entries.
18+
subtext:
19+
20+
# Optional: The change log or logs in which this entry should be included.
21+
# e.g. '[user]' or '[user, api]'
22+
# Include 'user' if the change is relevant to end users.
23+
# Include 'api' if there is a change to a library API.
24+
# Default: '[user]'
25+
change_logs: [user]

exporter/exporterhelper/internal/queue_sender.go

+30-5
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,7 @@ import (
1212
"go.uber.org/zap"
1313

1414
"go.opentelemetry.io/collector/component"
15+
"go.opentelemetry.io/collector/confmap"
1516
"go.opentelemetry.io/collector/exporter/exporterhelper/internal/queuebatch"
1617
"go.opentelemetry.io/collector/exporter/exporterhelper/internal/request"
1718
"go.opentelemetry.io/collector/exporter/exporterhelper/internal/sender"
@@ -32,8 +33,8 @@ func NewDefaultQueueConfig() QueueConfig {
3233
// By default, batches are 8192 spans, for a total of up to 8 million spans in the queue
3334
// This can be estimated at 1-4 GB worth of maximum memory usage
3435
// This default is probably still too high, and may be adjusted further down in a future release
35-
QueueSize: 1_000,
36-
Blocking: false,
36+
QueueSize: 1_000,
37+
BlockOnOverflow: false,
3738
}
3839
}
3940

@@ -48,12 +49,33 @@ type QueueConfig struct {
4849
NumConsumers int `mapstructure:"num_consumers"`
4950
// QueueSize is the maximum number of requests allowed in queue at any given time.
5051
QueueSize int `mapstructure:"queue_size"`
51-
// Blocking controls the queue behavior when full.
52-
// If true it blocks until enough space to add the new request to the queue.
52+
53+
// Deprecated: [v0.123.0] use `block_on_overflow`.
5354
Blocking bool `mapstructure:"blocking"`
55+
56+
// BlockOnOverflow determines the behavior when the component's TotalSize limit is reached.
57+
// If true, the component will wait for space; otherwise, operations will immediately return a retryable error.
58+
BlockOnOverflow bool `mapstructure:"block_on_overflow"`
59+
5460
// StorageID if not empty, enables the persistent storage and uses the component specified
5561
// as a storage extension for the persistent queue
5662
StorageID *component.ID `mapstructure:"storage"`
63+
64+
hasBlocking bool
65+
}
66+
67+
func (qCfg *QueueConfig) Unmarshal(conf *confmap.Conf) error {
68+
if err := conf.Unmarshal(qCfg); err != nil {
69+
return err
70+
}
71+
72+
// If user still uses the old blocking, override and will log error during initialization.
73+
if conf.IsSet("blocking") {
74+
qCfg.hasBlocking = true
75+
qCfg.BlockOnOverflow = qCfg.Blocking
76+
}
77+
78+
return nil
5779
}
5880

5981
// Validate checks if the Config is valid
@@ -77,6 +99,9 @@ func NewQueueSender(
7799
exportFailureMessage string,
78100
next sender.Sender[request.Request],
79101
) (sender.Sender[request.Request], error) {
102+
if qCfg.hasBlocking {
103+
qSet.Telemetry.Logger.Error("using deprecated field `blocking`")
104+
}
80105
exportFunc := func(ctx context.Context, req request.Request) error {
81106
// Have to read the number of items before sending the request since the request can
82107
// be modified by the downstream components like the batcher.
@@ -99,7 +124,7 @@ func newQueueBatchConfig(qCfg QueueConfig, bCfg BatcherConfig) queuebatch.Config
99124
Sizer: request.SizerTypeRequests,
100125
QueueSize: qCfg.QueueSize,
101126
NumConsumers: qCfg.NumConsumers,
102-
BlockOnOverflow: qCfg.Blocking,
127+
BlockOnOverflow: qCfg.BlockOnOverflow,
103128
StorageID: qCfg.StorageID,
104129
}
105130
if bCfg.Enabled {

exporter/exporterhelper/internal/queue_sender_test.go

+16
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,7 @@ import (
1515

1616
"go.opentelemetry.io/collector/component"
1717
"go.opentelemetry.io/collector/component/componenttest"
18+
"go.opentelemetry.io/collector/confmap"
1819
"go.opentelemetry.io/collector/exporter/exporterhelper/internal/queuebatch"
1920
"go.opentelemetry.io/collector/exporter/exporterhelper/internal/request"
2021
"go.opentelemetry.io/collector/exporter/exporterhelper/internal/requesttest"
@@ -45,6 +46,21 @@ func TestNewQueueSenderFailedRequestDropped(t *testing.T) {
4546
assert.Equal(t, "Exporting failed. Dropping data.", observed.All()[0].Message)
4647
}
4748

49+
func TestQueueConfig_DeprecatedBlockingUnmarshal(t *testing.T) {
50+
conf := confmap.NewFromStringMap(map[string]any{
51+
"enabled": true,
52+
"num_consumers": 2,
53+
"queue_size": 100,
54+
"blocking": true,
55+
})
56+
57+
qCfg := QueueConfig{}
58+
assert.False(t, qCfg.BlockOnOverflow)
59+
require.NoError(t, conf.Unmarshal(&qCfg))
60+
assert.True(t, qCfg.BlockOnOverflow)
61+
assert.True(t, qCfg.hasBlocking)
62+
}
63+
4864
func TestQueueConfig_Validate(t *testing.T) {
4965
qCfg := NewDefaultQueueConfig()
5066
require.NoError(t, qCfg.Validate())

exporter/exporterhelper/queue_batch.go

+1-11
Original file line numberDiff line numberDiff line change
@@ -61,17 +61,7 @@ func WithQueueBatch(cfg QueueBatchConfig, set QueueBatchSettings) Option {
6161

6262
// NewDefaultQueueConfig returns the default config for QueueConfig.
6363
// By default, the queue stores 1000 items of telemetry and is non-blocking when full.
64-
func NewDefaultQueueConfig() QueueConfig {
65-
return QueueConfig{
66-
Enabled: true,
67-
NumConsumers: 10,
68-
// By default, batches are 8192 spans, for a total of up to 8 million spans in the queue
69-
// This can be estimated at 1-4 GB worth of maximum memory usage
70-
// This default is probably still too high, and may be adjusted further down in a future release
71-
QueueSize: 1_000,
72-
Blocking: false,
73-
}
74-
}
64+
var NewDefaultQueueConfig = internal.NewDefaultQueueConfig
7565

7666
// BatcherConfig defines a configuration for batching requests based on a timeout and a minimum number of items.
7767
// Experimental: This API is at the early stage of development and may change without backward compatibility

exporter/exporterhelper/xexporterhelper/go.mod

+13
Original file line numberDiff line numberDiff line change
@@ -29,15 +29,24 @@ require (
2929
github.com/davecgh/go-spew v1.1.1 // indirect
3030
github.com/go-logr/logr v1.4.2 // indirect
3131
github.com/go-logr/stdr v1.2.2 // indirect
32+
github.com/go-viper/mapstructure/v2 v2.2.1 // indirect
3233
github.com/gogo/protobuf v1.3.2 // indirect
3334
github.com/google/uuid v1.6.0 // indirect
35+
github.com/hashicorp/go-version v1.7.0 // indirect
3436
github.com/json-iterator/go v1.1.12 // indirect
37+
github.com/knadh/koanf/maps v0.1.1 // indirect
38+
github.com/knadh/koanf/providers/confmap v0.1.0 // indirect
39+
github.com/knadh/koanf/v2 v2.1.2 // indirect
40+
github.com/mitchellh/copystructure v1.2.0 // indirect
41+
github.com/mitchellh/reflectwalk v1.0.2 // indirect
3542
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
3643
github.com/modern-go/reflect2 v1.0.2 // indirect
3744
github.com/pmezard/go-difflib v1.0.0 // indirect
3845
go.opentelemetry.io/auto/sdk v1.1.0 // indirect
46+
go.opentelemetry.io/collector/confmap v1.28.1 // indirect
3947
go.opentelemetry.io/collector/extension v1.28.1 // indirect
4048
go.opentelemetry.io/collector/extension/xextension v0.122.1 // indirect
49+
go.opentelemetry.io/collector/featuregate v1.28.1 // indirect
4150
go.opentelemetry.io/collector/pdata v1.28.1 // indirect
4251
go.opentelemetry.io/collector/pipeline v0.122.1 // indirect
4352
go.opentelemetry.io/collector/receiver v1.28.1 // indirect
@@ -98,3 +107,7 @@ replace go.opentelemetry.io/collector/consumer/consumererror => ../../../consume
98107
replace go.opentelemetry.io/collector/extension/extensiontest => ../../../extension/extensiontest
99108

100109
replace go.opentelemetry.io/collector/extension/xextension => ../../../extension/xextension
110+
111+
replace go.opentelemetry.io/collector/featuregate => ../../../featuregate
112+
113+
replace go.opentelemetry.io/collector/confmap => ../../../confmap

exporter/exporterhelper/xexporterhelper/go.sum

+18
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

exporter/exportertest/go.mod

+13
Original file line numberDiff line numberDiff line change
@@ -26,15 +26,24 @@ require (
2626
github.com/davecgh/go-spew v1.1.1 // indirect
2727
github.com/go-logr/logr v1.4.2 // indirect
2828
github.com/go-logr/stdr v1.2.2 // indirect
29+
github.com/go-viper/mapstructure/v2 v2.2.1 // indirect
2930
github.com/gogo/protobuf v1.3.2 // indirect
31+
github.com/hashicorp/go-version v1.7.0 // indirect
3032
github.com/json-iterator/go v1.1.12 // indirect
33+
github.com/knadh/koanf/maps v0.1.1 // indirect
34+
github.com/knadh/koanf/providers/confmap v0.1.0 // indirect
35+
github.com/knadh/koanf/v2 v2.1.2 // indirect
36+
github.com/mitchellh/copystructure v1.2.0 // indirect
37+
github.com/mitchellh/reflectwalk v1.0.2 // indirect
3138
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
3239
github.com/modern-go/reflect2 v1.0.2 // indirect
3340
github.com/pmezard/go-difflib v1.0.0 // indirect
3441
go.opentelemetry.io/auto/sdk v1.1.0 // indirect
42+
go.opentelemetry.io/collector/confmap v1.28.1 // indirect
3543
go.opentelemetry.io/collector/consumer/xconsumer v0.122.1 // indirect
3644
go.opentelemetry.io/collector/extension v1.28.1 // indirect
3745
go.opentelemetry.io/collector/extension/xextension v0.122.1 // indirect
46+
go.opentelemetry.io/collector/featuregate v1.28.1 // indirect
3847
go.opentelemetry.io/collector/receiver/xreceiver v0.122.1 // indirect
3948
go.opentelemetry.io/otel v1.35.0 // indirect
4049
go.opentelemetry.io/otel/metric v1.35.0 // indirect
@@ -88,3 +97,7 @@ replace go.opentelemetry.io/collector/consumer/consumererror => ../../consumer/c
8897
replace go.opentelemetry.io/collector/extension/extensiontest => ../../extension/extensiontest
8998

9099
replace go.opentelemetry.io/collector/extension/xextension => ../../extension/xextension
100+
101+
replace go.opentelemetry.io/collector/featuregate => ../../featuregate
102+
103+
replace go.opentelemetry.io/collector/confmap => ../../confmap

exporter/exportertest/go.sum

+18
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

0 commit comments

Comments
 (0)