Pavel Tupitsyn created IGNITE-25669:
---------------------------------------

             Summary: Java thin 3.0: Netty buffer leak detected on TC
                 Key: IGNITE-25669
                 URL: https://issues.apache.org/jira/browse/IGNITE-25669
             Project: Ignite
          Issue Type: Bug
          Components: thin clients ai3
            Reporter: Pavel Tupitsyn
            Assignee: Pavel Tupitsyn
             Fix For: 3.1


{code}
[2025-06-07T06:39:08,177][ERROR][testNode_150-network-worker-12][ResourceLeakDetector]
 LEAK: ByteBuf.release() was not called before it's garbage-collected. See 
https://netty.io/wiki/reference-counted-objects.html for more information.
06:40:29     Recent access records:
06:40:29     #1:
06:40:29       
org.apache.ignite.internal.client.proto.ClientMessageUnpacker.close(ClientMessageUnpacker.java:878)
06:40:29       
org.apache.ignite.internal.client.TcpClientChannel.onMessage(TcpClientChannel.java:284)
06:40:29       
org.apache.ignite.internal.client.io.netty.NettyClientConnection.onMessage(NettyClientConnection.java:109)
06:40:29       
org.apache.ignite.internal.client.io.netty.NettyClientMessageHandler.channelRead(NettyClientMessageHandler.java:25)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:444)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:412)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.fireChannelRead(ByteToMessageDecoder.java:346)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.channelRead(ByteToMessageDecoder.java:318)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:444)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:412)
06:40:29       
io.netty.channel.DefaultChannelPipeline$HeadContext.channelRead(DefaultChannelPipeline.java:1357)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:440)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.DefaultChannelPipeline.fireChannelRead(DefaultChannelPipeline.java:868)
06:40:29       
io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:166)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:796)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:732)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:658)
06:40:29       io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:562)
06:40:29       
io.netty.util.concurrent.SingleThreadEventExecutor$4.run(SingleThreadEventExecutor.java:998)
06:40:29       
io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
06:40:29       
io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
06:40:29       java.base/java.lang.Thread.run(Thread.java:833)
06:40:29     #2:
06:40:29       
io.netty.buffer.AdvancedLeakAwareByteBuf.readByte(AdvancedLeakAwareByteBuf.java:401)
06:40:29       
org.apache.ignite.internal.client.proto.ClientMessageUnpacker.unpackInt(ClientMessageUnpacker.java:99)
06:40:29       
org.apache.ignite.internal.client.TcpClientChannel.processNextMessage(TcpClientChannel.java:460)
06:40:29       
org.apache.ignite.internal.client.TcpClientChannel.onMessage(TcpClientChannel.java:283)
06:40:29       
org.apache.ignite.internal.client.io.netty.NettyClientConnection.onMessage(NettyClientConnection.java:109)
06:40:29       
org.apache.ignite.internal.client.io.netty.NettyClientMessageHandler.channelRead(NettyClientMessageHandler.java:25)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:444)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:412)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.fireChannelRead(ByteToMessageDecoder.java:346)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.channelRead(ByteToMessageDecoder.java:318)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:444)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:412)
06:40:29       
io.netty.channel.DefaultChannelPipeline$HeadContext.channelRead(DefaultChannelPipeline.java:1357)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:440)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.DefaultChannelPipeline.fireChannelRead(DefaultChannelPipeline.java:868)
06:40:29       
io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:166)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:796)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:732)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:658)
06:40:29       io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:562)
06:40:29       
io.netty.util.concurrent.SingleThreadEventExecutor$4.run(SingleThreadEventExecutor.java:998)
06:40:29       
io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
06:40:29       
io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
06:40:29       java.base/java.lang.Thread.run(Thread.java:833)
06:40:29     #3:
06:40:29       
io.netty.buffer.AdvancedLeakAwareByteBuf.readByte(AdvancedLeakAwareByteBuf.java:401)
06:40:29       
org.apache.ignite.internal.client.proto.ClientMessageUnpacker.unpackLong(ClientMessageUnpacker.java:285)
06:40:29       
org.apache.ignite.internal.client.TcpClientChannel.processNextMessage(TcpClientChannel.java:459)
06:40:29       
org.apache.ignite.internal.client.TcpClientChannel.onMessage(TcpClientChannel.java:283)
06:40:29       
org.apache.ignite.internal.client.io.netty.NettyClientConnection.onMessage(NettyClientConnection.java:109)
06:40:29       
org.apache.ignite.internal.client.io.netty.NettyClientMessageHandler.channelRead(NettyClientMessageHandler.java:25)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:444)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:412)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.fireChannelRead(ByteToMessageDecoder.java:346)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.channelRead(ByteToMessageDecoder.java:318)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:444)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:412)
06:40:29       
io.netty.channel.DefaultChannelPipeline$HeadContext.channelRead(DefaultChannelPipeline.java:1357)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:440)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.DefaultChannelPipeline.fireChannelRead(DefaultChannelPipeline.java:868)
06:40:29       
io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:166)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:796)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:732)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:658)
06:40:29       io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:562)
06:40:29       
io.netty.util.concurrent.SingleThreadEventExecutor$4.run(SingleThreadEventExecutor.java:998)
06:40:29       
io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
06:40:29       
io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
06:40:29       java.base/java.lang.Thread.run(Thread.java:833)
06:40:29     #4:
06:40:29       Hint: 'NettyClientMessageHandler#0' will handle the message from 
this point.
06:40:29       
io.netty.channel.DefaultChannelPipeline.touch(DefaultChannelPipeline.java:115)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:417)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:412)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.fireChannelRead(ByteToMessageDecoder.java:346)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.channelRead(ByteToMessageDecoder.java:318)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:444)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.fireChannelRead(AbstractChannelHandlerContext.java:412)
06:40:29       
io.netty.channel.DefaultChannelPipeline$HeadContext.channelRead(DefaultChannelPipeline.java:1357)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:440)
06:40:29       
io.netty.channel.AbstractChannelHandlerContext.invokeChannelRead(AbstractChannelHandlerContext.java:420)
06:40:29       
io.netty.channel.DefaultChannelPipeline.fireChannelRead(DefaultChannelPipeline.java:868)
06:40:29       
io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:166)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:796)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:732)
06:40:29       
io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:658)
06:40:29       io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:562)
06:40:29       
io.netty.util.concurrent.SingleThreadEventExecutor$4.run(SingleThreadEventExecutor.java:998)
06:40:29       
io.netty.util.internal.ThreadExecutorMap$2.run(ThreadExecutorMap.java:74)
06:40:29       
io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
06:40:29       java.base/java.lang.Thread.run(Thread.java:833)
06:40:29     Created at:
06:40:29       
io.netty.buffer.SimpleLeakAwareByteBuf.unwrappedDerived(SimpleLeakAwareByteBuf.java:144)
06:40:29       
io.netty.buffer.SimpleLeakAwareByteBuf.retainedSlice(SimpleLeakAwareByteBuf.java:57)
06:40:29       
io.netty.buffer.AdvancedLeakAwareByteBuf.retainedSlice(AdvancedLeakAwareByteBuf.java:96)
06:40:29       
io.netty.handler.codec.LengthFieldBasedFrameDecoder.extractFrame(LengthFieldBasedFrameDecoder.java:502)
06:40:29       
io.netty.handler.codec.LengthFieldBasedFrameDecoder.decode(LengthFieldBasedFrameDecoder.java:440)
06:40:29       
org.apache.ignite.internal.client.proto.ClientMessageDecoder.decode(ClientMessageDecoder.java:48)
06:40:29       
io.netty.handler.codec.LengthFieldBasedFrameDecoder.decode(LengthFieldBasedFrameDecoder.java:333)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.decodeRemovalReentryProtection(ByteToMessageDecoder.java:530)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.callDecode(ByteToMessageDecoder.java:469)
06:40:29       
io.netty.handler.codec.ByteToMessageDecoder.channelRead(ByteToMessageDecoder.java:290)
{code}



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to