From 66506f9a1184b7a938e979a5a875cb528f7e20b7 Mon Sep 17 00:00:00 2001 From: "jeffrey (Hongji Ye)" Date: Thu, 28 Jul 2022 23:41:22 -0700 Subject: [PATCH] Avoid buffer copies in `RedisStateMachine` #2173 Original pull request: #2174 --- .../lettuce/core/protocol/CommandHandler.java | 2 +- .../core/protocol/RedisStateMachine.java | 23 ++++++------------- .../RedisStateMachineResp2UnitTests.java | 2 +- .../RedisStateMachineResp3UnitTests.java | 2 +- .../core/protocol/StateMachineUnitTests.java | 2 +- .../protocol/RedisStateMachineBenchmark.java | 2 +- 6 files changed, 12 insertions(+), 21 deletions(-) diff --git a/src/main/java/io/lettuce/core/protocol/CommandHandler.java b/src/main/java/io/lettuce/core/protocol/CommandHandler.java index 4fc3422f7e..fc35c9c99b 100644 --- a/src/main/java/io/lettuce/core/protocol/CommandHandler.java +++ b/src/main/java/io/lettuce/core/protocol/CommandHandler.java @@ -213,7 +213,7 @@ public void channelRegistered(ChannelHandlerContext ctx) throws Exception { setState(LifecycleState.REGISTERED); buffer = ctx.alloc().buffer(8192 * 8); - rsm = new RedisStateMachine(ctx.alloc()); + rsm = new RedisStateMachine(); ctx.fireChannelRegistered(); } diff --git a/src/main/java/io/lettuce/core/protocol/RedisStateMachine.java b/src/main/java/io/lettuce/core/protocol/RedisStateMachine.java index e40946538d..c016474608 100644 --- a/src/main/java/io/lettuce/core/protocol/RedisStateMachine.java +++ b/src/main/java/io/lettuce/core/protocol/RedisStateMachine.java @@ -231,8 +231,6 @@ public String toString() { private final boolean debugEnabled = logger.isDebugEnabled(); - private final ByteBuf responseElementBuffer; - private final AtomicBoolean closed = new AtomicBoolean(); private final Resp2LongProcessor longProcessor = new Resp2LongProcessor(); @@ -244,8 +242,8 @@ public String toString() { /** * Initialize a new instance. */ - public RedisStateMachine(ByteBufAllocator alloc) { - this.responseElementBuffer = alloc.buffer(1024); + public RedisStateMachine() { + } public boolean isDiscoverProtocol() { @@ -591,7 +589,7 @@ public void reset() { */ public void close() { if (closed.compareAndSet(false, true)) { - responseElementBuffer.release(); + // free resources if any } } @@ -673,18 +671,11 @@ private ByteBuffer readBytes(ByteBuf buffer, int count) { } private ByteBuffer readBytes0(ByteBuf buffer, int count) { + final ByteBuffer byteBuffer = buffer.internalNioBuffer(buffer.readerIndex(), count); - ByteBuffer bytes; - responseElementBuffer.clear(); - - if (responseElementBuffer.capacity() < count) { - responseElementBuffer.capacity(count); - } - - buffer.readBytes(responseElementBuffer, count); - bytes = responseElementBuffer.internalNioBuffer(0, count); - - return bytes; + // advance reader index + buffer.readerIndex(buffer.readerIndex() + count); + return byteBuffer; } /** diff --git a/src/test/java/io/lettuce/core/protocol/RedisStateMachineResp2UnitTests.java b/src/test/java/io/lettuce/core/protocol/RedisStateMachineResp2UnitTests.java index 2c515a9d30..6d1d1d5d0c 100644 --- a/src/test/java/io/lettuce/core/protocol/RedisStateMachineResp2UnitTests.java +++ b/src/test/java/io/lettuce/core/protocol/RedisStateMachineResp2UnitTests.java @@ -74,7 +74,7 @@ static void afterClass() { @BeforeEach final void createStateMachine() { output = new StatusOutput<>(codec); - rsm = new RedisStateMachine(ByteBufAllocator.DEFAULT); + rsm = new RedisStateMachine(); } @AfterEach diff --git a/src/test/java/io/lettuce/core/protocol/RedisStateMachineResp3UnitTests.java b/src/test/java/io/lettuce/core/protocol/RedisStateMachineResp3UnitTests.java index 0ed8ab056b..dcc0468d65 100644 --- a/src/test/java/io/lettuce/core/protocol/RedisStateMachineResp3UnitTests.java +++ b/src/test/java/io/lettuce/core/protocol/RedisStateMachineResp3UnitTests.java @@ -74,7 +74,7 @@ static void afterClass() { @BeforeEach final void createStateMachine() { output = new StatusOutput<>(codec); - rsm = new RedisStateMachine(ByteBufAllocator.DEFAULT); + rsm = new RedisStateMachine(); rsm.setProtocolVersion(ProtocolVersion.RESP3); } diff --git a/src/test/java/io/lettuce/core/protocol/StateMachineUnitTests.java b/src/test/java/io/lettuce/core/protocol/StateMachineUnitTests.java index fd0ec527eb..93c0be27a2 100644 --- a/src/test/java/io/lettuce/core/protocol/StateMachineUnitTests.java +++ b/src/test/java/io/lettuce/core/protocol/StateMachineUnitTests.java @@ -67,7 +67,7 @@ static void afterClass() { @BeforeEach final void createStateMachine() { output = new StatusOutput<>(codec); - rsm = new RedisStateMachine(ByteBufAllocator.DEFAULT); + rsm = new RedisStateMachine(); } @AfterEach diff --git a/src/test/jmh/io/lettuce/core/protocol/RedisStateMachineBenchmark.java b/src/test/jmh/io/lettuce/core/protocol/RedisStateMachineBenchmark.java index dd20e43ea6..d51eb41b6a 100644 --- a/src/test/jmh/io/lettuce/core/protocol/RedisStateMachineBenchmark.java +++ b/src/test/jmh/io/lettuce/core/protocol/RedisStateMachineBenchmark.java @@ -60,7 +60,7 @@ public void set(long integer) { private ByteBuf masterBuffer; - private final RedisStateMachine stateMachine = new RedisStateMachine(ByteBufAllocator.DEFAULT); + private final RedisStateMachine stateMachine = new RedisStateMachine(); private final byte[] payload = ("*3\r\n" + // "$4\r\n" + // "LLEN\r\n" + //