Skip to content

Commit 8cfd032

Browse files
committed
Deprecate blocking in favor of block_on_overflow
Signed-off-by: Bogdan Drutu <[email protected]>
1 parent 7c2c26d commit 8cfd032

File tree

10 files changed

+156
-5
lines changed

10 files changed

+156
-5
lines changed

.chloggen/deprecate-blocking.yaml

Lines changed: 25 additions & 0 deletions
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

Lines changed: 30 additions & 5 deletions
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"
@@ -33,8 +34,8 @@ func NewDefaultQueueConfig() QueueConfig {
3334
// By default, batches are 8192 spans, for a total of up to 8 million spans in the queue
3435
// This can be estimated at 1-4 GB worth of maximum memory usage
3536
// This default is probably still too high, and may be adjusted further down in a future release
36-
QueueSize: 1_000,
37-
Blocking: false,
37+
QueueSize: 1_000,
38+
BlockOnOverflow: false,
3839
}
3940
}
4041

@@ -55,12 +56,33 @@ type QueueConfig struct {
5556

5657
// NumConsumers is the number of consumers from the queue.
5758
NumConsumers int `mapstructure:"num_consumers"`
58-
// Blocking controls the queue behavior when full.
59-
// If true it blocks until enough space to add the new request to the queue.
59+
60+
// Deprecated: [v0.123.0] use `block_on_overflow`.
6061
Blocking bool `mapstructure:"blocking"`
62+
63+
// BlockOnOverflow determines the behavior when the component's QueueSize limit is reached.
64+
// If true, the component will wait for space; otherwise, operations will immediately return a retryable error.
65+
BlockOnOverflow bool `mapstructure:"block_on_overflow"`
66+
6167
// StorageID if not empty, enables the persistent storage and uses the component specified
6268
// as a storage extension for the persistent queue
6369
StorageID *component.ID `mapstructure:"storage"`
70+
71+
hasBlocking bool
72+
}
73+
74+
func (qCfg *QueueConfig) Unmarshal(conf *confmap.Conf) error {
75+
if err := conf.Unmarshal(qCfg); err != nil {
76+
return err
77+
}
78+
79+
// If user still uses the old blocking, override and will log error during initialization.
80+
if conf.IsSet("blocking") {
81+
qCfg.hasBlocking = true
82+
qCfg.BlockOnOverflow = qCfg.Blocking
83+
}
84+
85+
return nil
6486
}
6587

6688
// Validate checks if the Config is valid
@@ -92,6 +114,9 @@ func NewQueueSender(
92114
exportFailureMessage string,
93115
next sender.Sender[request.Request],
94116
) (sender.Sender[request.Request], error) {
117+
if qCfg.hasBlocking {
118+
qSet.Telemetry.Logger.Error("using deprecated field `blocking`")
119+
}
95120
exportFunc := func(ctx context.Context, req request.Request) error {
96121
// Have to read the number of items before sending the request since the request can
97122
// be modified by the downstream components like the batcher.
@@ -114,7 +139,7 @@ func newQueueBatchConfig(qCfg QueueConfig, bCfg BatcherConfig) queuebatch.Config
114139
Sizer: qCfg.Sizer,
115140
QueueSize: qCfg.QueueSize,
116141
NumConsumers: qCfg.NumConsumers,
117-
BlockOnOverflow: qCfg.Blocking,
142+
BlockOnOverflow: qCfg.BlockOnOverflow,
118143
StorageID: qCfg.StorageID,
119144
}
120145
if bCfg.Enabled {

exporter/exporterhelper/internal/queue_sender_test.go

Lines changed: 16 additions & 0 deletions
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/xexporterhelper/go.mod

Lines changed: 13 additions & 0 deletions
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

Lines changed: 14 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

exporter/exportertest/go.mod

Lines changed: 13 additions & 0 deletions
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

Lines changed: 14 additions & 0 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

exporter/go.mod

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,7 @@ require (
88
go.opentelemetry.io/collector/component v1.28.1
99
go.opentelemetry.io/collector/component/componenttest v0.122.1
1010
go.opentelemetry.io/collector/config/configretry v1.28.1
11+
go.opentelemetry.io/collector/confmap v1.28.1
1112
go.opentelemetry.io/collector/consumer v1.28.1
1213
go.opentelemetry.io/collector/consumer/consumererror v0.122.1
1314
go.opentelemetry.io/collector/consumer/consumertest v0.122.1
@@ -31,16 +32,24 @@ require (
3132
github.com/davecgh/go-spew v1.1.1 // indirect
3233
github.com/go-logr/logr v1.4.2 // indirect
3334
github.com/go-logr/stdr v1.2.2 // indirect
35+
github.com/go-viper/mapstructure/v2 v2.2.1 // indirect
3436
github.com/gogo/protobuf v1.3.2 // indirect
3537
github.com/google/uuid v1.6.0 // indirect
38+
github.com/hashicorp/go-version v1.7.0 // indirect
3639
github.com/json-iterator/go v1.1.12 // indirect
40+
github.com/knadh/koanf/maps v0.1.1 // indirect
41+
github.com/knadh/koanf/providers/confmap v0.1.0 // indirect
42+
github.com/knadh/koanf/v2 v2.1.2 // indirect
43+
github.com/mitchellh/copystructure v1.2.0 // indirect
44+
github.com/mitchellh/reflectwalk v1.0.2 // indirect
3745
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
3846
github.com/modern-go/reflect2 v1.0.2 // indirect
3947
github.com/pmezard/go-difflib v1.0.0 // indirect
4048
go.opentelemetry.io/auto/sdk v1.1.0 // indirect
4149
go.opentelemetry.io/collector/consumer/xconsumer v0.122.1 // indirect
4250
go.opentelemetry.io/collector/exporter/xexporter v0.122.1 // indirect
4351
go.opentelemetry.io/collector/extension v1.28.1 // indirect
52+
go.opentelemetry.io/collector/featuregate v1.28.1 // indirect
4453
go.opentelemetry.io/collector/pdata/pprofile v0.122.1 // indirect
4554
go.opentelemetry.io/collector/receiver v1.28.1 // indirect
4655
go.opentelemetry.io/collector/receiver/receivertest v0.122.1 // indirect
@@ -93,3 +102,7 @@ replace go.opentelemetry.io/collector/consumer/consumererror => ../consumer/cons
93102
replace go.opentelemetry.io/collector/extension/extensiontest => ../extension/extensiontest
94103

95104
replace go.opentelemetry.io/collector/extension/xextension => ../extension/xextension
105+
106+
replace go.opentelemetry.io/collector/featuregate => ../featuregate
107+
108+
replace go.opentelemetry.io/collector/confmap => ../confmap

0 commit comments

Comments
 (0)