From d05ced115d6899aad38c9c592faa582906f34f4f Mon Sep 17 00:00:00 2001 From: marc-adaptive Date: Thu, 2 Jan 2025 08:48:15 -0500 Subject: [PATCH] In the case a session disconnects during a replay, downgrade error handler logging --- .../engine/framer/FixSenderEndPoints.java | 22 +------------------ .../artio/engine/framer/Framer.java | 2 +- 2 files changed, 2 insertions(+), 22 deletions(-) diff --git a/artio-core/src/main/java/uk/co/real_logic/artio/engine/framer/FixSenderEndPoints.java b/artio-core/src/main/java/uk/co/real_logic/artio/engine/framer/FixSenderEndPoints.java index 0fc8c5bbc5..77844cdfad 100644 --- a/artio-core/src/main/java/uk/co/real_logic/artio/engine/framer/FixSenderEndPoints.java +++ b/artio-core/src/main/java/uk/co/real_logic/artio/engine/framer/FixSenderEndPoints.java @@ -17,7 +17,6 @@ import io.aeron.logbuffer.ControlledFragmentHandler.Action; import org.agrona.DirectBuffer; -import org.agrona.ErrorHandler; import org.agrona.collections.Long2ObjectHashMap; import uk.co.real_logic.artio.DebugLogger; import uk.co.real_logic.artio.LogTag; @@ -35,7 +34,6 @@ class FixSenderEndPoints implements AutoCloseable "SEPs.missReplayComplete, connId=%s, corrId=%s, slow=%s"); private final Long2ObjectHashMap connectionIdToSenderEndpoint = new Long2ObjectHashMap<>(); - private final ErrorHandler errorHandler; private final LongToIntFunction libraryLookup = this::libraryLookup; private int libraryLookup(final long sessionId) @@ -53,11 +51,6 @@ private int libraryLookup(final long sessionId) private long timeInMs; - FixSenderEndPoints(final ErrorHandler errorHandler) - { - this.errorHandler = errorHandler; - } - public void add(final FixSenderEndPoint senderEndPoint) { connectionIdToSenderEndpoint.put(senderEndPoint.connectionId(), senderEndPoint); @@ -134,21 +127,8 @@ Action onReplayMessage( { return endPoint.onReplayMessage(buffer, offset, length, timeInMs, sequenceNumber); } - else - { - logReplayError(connectionId, buffer, offset, length); - - return CONTINUE; - } - } + return CONTINUE; - private void logReplayError(final long connectionId, final DirectBuffer buffer, final int offset, final int length) - { - errorHandler.onError(new IllegalArgumentException(String.format( - "Failed to replay message on conn=%1$d [%2$s], this probably indicates the connection has disconnected " + - "from Artio whilst this message was in the process of being replayed", - connectionId, - buffer.getStringWithoutLengthUtf8(offset, length)))); } Action onReplayComplete(final long connectionId, final long correlationId, final boolean slow) diff --git a/artio-core/src/main/java/uk/co/real_logic/artio/engine/framer/Framer.java b/artio-core/src/main/java/uk/co/real_logic/artio/engine/framer/Framer.java index a59d38f7dd..81b469a23f 100644 --- a/artio-core/src/main/java/uk/co/real_logic/artio/engine/framer/Framer.java +++ b/artio-core/src/main/java/uk/co/real_logic/artio/engine/framer/Framer.java @@ -260,7 +260,7 @@ class Framer implements Agent, EngineEndPointHandler, ProtocolHandler this.agentNamePrefix = agentNamePrefix; this.inboundCompletionPosition = inboundCompletionPosition; this.outboundLibraryCompletionPosition = outboundLibraryCompletionPosition; - this.fixSenderEndPoints = new FixSenderEndPoints(errorHandler); + this.fixSenderEndPoints = new FixSenderEndPoints(); this.countersReader = countersReader; this.inboundIndexRegistrationId = inboundIndexRegistrationId; this.outboundIndexRegistrationId = outboundIndexRegistrationId;