DefaultChannelPipeline needs to release objects
Motiviation: If user events or excpetions reach the tail end of the pipeline they are not released. This could result in buffer leaks. Motivation: - Use the ReferenceCountUtil.release to release objects for the userEventTriggered and exceptionCaught methods on DefaultChannelPipeline Result: 2 less areas where buffer leaks can occur.
This commit is contained in:
parent
93f08aa28b
commit
c9a0bf4859
@ -1023,13 +1023,22 @@ final class DefaultChannelPipeline implements ChannelPipeline {
|
|||||||
public void handlerRemoved(ChannelHandlerContext ctx) throws Exception { }
|
public void handlerRemoved(ChannelHandlerContext ctx) throws Exception { }
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void userEventTriggered(ChannelHandlerContext ctx, Object evt) throws Exception { }
|
public void userEventTriggered(ChannelHandlerContext ctx, Object evt) throws Exception {
|
||||||
|
// This may not be a configuration error and so don't log anything.
|
||||||
|
// The event may be superfluous for the current pipeline configuration.
|
||||||
|
ReferenceCountUtil.release(evt);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
|
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
|
||||||
logger.warn(
|
try {
|
||||||
"An exceptionCaught() event was fired, and it reached at the tail of the pipeline. " +
|
logger.warn(
|
||||||
"It usually means the last handler in the pipeline did not handle the exception.", cause);
|
"An exceptionCaught() event was fired, and it reached at the tail of the pipeline. " +
|
||||||
|
"It usually means the last handler in the pipeline did not handle the exception.",
|
||||||
|
cause);
|
||||||
|
} finally {
|
||||||
|
ReferenceCountUtil.release(cause);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
x
Reference in New Issue
Block a user