From 36b34bfc4732e09110e7e5f5c10214f6ad49cd2a Mon Sep 17 00:00:00 2001 From: Ben Ye Date: Sat, 1 Jan 2022 13:16:09 -0800 Subject: [PATCH 1/2] add additional batch overhead in jaeger agent udp exporter Signed-off-by: Ben Ye --- exporters/jaeger/agent.go | 11 ++++++++--- exporters/jaeger/agent_test.go | 4 ++-- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/exporters/jaeger/agent.go b/exporters/jaeger/agent.go index 5dbb5805c9b..ce53e4386b2 100644 --- a/exporters/jaeger/agent.go +++ b/exporters/jaeger/agent.go @@ -28,8 +28,13 @@ import ( "go.opentelemetry.io/otel/exporters/jaeger/internal/third_party/thrift/lib/go/thrift" ) -// udpPacketMaxLength is the max size of UDP packet we want to send, synced with jaeger-agent -const udpPacketMaxLength = 65000 +const ( + // udpPacketMaxLength is the max size of UDP packet we want to send, synced with jaeger-agent + udpPacketMaxLength = 65000 + // emitBatchOverhead is the additional overhead bytes used for enveloping the datagram, + // synced with jaeger-agent https://github.com/jaegertracing/jaeger-client-go/blob/master/transport_udp.go#L37 + emitBatchOverhead = 70 +) // agentClientUDP is a UDP client to Jaeger agent that implements gen.Agent interface. type agentClientUDP struct { @@ -67,7 +72,7 @@ func newAgentClientUDP(params agentClientUDPParams) (*agentClientUDP, error) { } if params.MaxPacketSize <= 0 { - params.MaxPacketSize = udpPacketMaxLength + params.MaxPacketSize = udpPacketMaxLength - emitBatchOverhead } if params.AttemptReconnecting && params.AttemptReconnectInterval <= 0 { diff --git a/exporters/jaeger/agent_test.go b/exporters/jaeger/agent_test.go index 62de111dae5..933d364e3df 100644 --- a/exporters/jaeger/agent_test.go +++ b/exporters/jaeger/agent_test.go @@ -73,7 +73,7 @@ func TestNewAgentClientUDPWithParamsDefaults(t *testing.T) { }) assert.NoError(t, err) assert.NotNil(t, agentClient) - assert.Equal(t, udpPacketMaxLength, agentClient.maxPacketSize) + assert.Equal(t, udpPacketMaxLength-emitBatchOverhead, agentClient.maxPacketSize) if assert.IsType(t, &reconnectingUDPConn{}, agentClient.connUDP) { assert.Equal(t, (*log.Logger)(nil), agentClient.connUDP.(*reconnectingUDPConn).logger) @@ -97,7 +97,7 @@ func TestNewAgentClientUDPWithParamsReconnectingDisabled(t *testing.T) { }) assert.NoError(t, err) assert.NotNil(t, agentClient) - assert.Equal(t, udpPacketMaxLength, agentClient.maxPacketSize) + assert.Equal(t, udpPacketMaxLength-emitBatchOverhead, agentClient.maxPacketSize) assert.IsType(t, &net.UDPConn{}, agentClient.connUDP) From e5d73748a4f18d21ee8eb98351754a2896c789ed Mon Sep 17 00:00:00 2001 From: Ben Ye Date: Mon, 3 Jan 2022 10:39:54 -0800 Subject: [PATCH 2/2] update changelog Signed-off-by: Ben Ye --- CHANGELOG.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 1bc1eef716d..3c524fc28b7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,10 @@ This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.htm ## [Unreleased] +### Changed + +- Jaeger exporter takes into additional 70 bytes overhead into consideration when sending UDP packets (#2489) + ### Deprecated - Deprecate module `"go.opentelemetry.io/otel/sdk/export/metric"`, new functionality available in "go.opentelemetry.io/otel/sdk/metric" module: