- java.lang.Object
- 
- io.netty5.handler.flow.FlowControlHandler
 
- 
- All Implemented Interfaces:
- ChannelHandler
 
 public class FlowControlHandler extends Object implements ChannelHandler TheFlowControlHandlerensures that only one message perread()is sent downstream. Classes such asByteToMessageDecoderorMessageToByteEncoderare free to emit as many events as they like for any given input. A channel's auto reading configuration doesn't usually apply in these scenarios. This is causing problems in downstreamChannelHandlers that would like to hold subsequent events while they're processing one event. It's a common problem with theHttpObjectDecoderthat will very often fire anHttpRequestthat is immediately followed by aLastHttpContentevent.{@code ChannelPipeline pipeline = ...; pipeline.addLast(new HttpServerCodec()); pipeline.addLast(new FlowControlHandler()); pipeline.addLast(new MyExampleHandler()); class MyExampleHandler extends ChannelInboundHandlerAdapter {
- 
- 
Constructor SummaryConstructors Constructor Description FlowControlHandler()FlowControlHandler(boolean releaseMessages)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidchannelInactive(ChannelHandlerContext ctx)TheChannelof theChannelHandlerContextwas registered is now inactive and reached its end of lifetime.voidchannelRead(ChannelHandlerContext ctx, Object msg)Invoked when the currentChannelhas read a message from the peer.voidchannelReadComplete(ChannelHandlerContext ctx)Invoked when the last message read by the current read operation has been consumed byChannelHandler.channelRead(ChannelHandlerContext, Object).voidhandlerRemoved(ChannelHandlerContext ctx)Gets called after theChannelHandlerwas removed from the actual context and it doesn't handle events anymore.voidread(ChannelHandlerContext ctx)InterceptsChannelHandlerContext.read().- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface io.netty5.channel.ChannelHandlerbind, channelActive, channelExceptionCaught, channelInboundEvent, channelRegistered, channelShutdown, channelUnregistered, channelWritabilityChanged, close, connect, deregister, disconnect, flush, handlerAdded, isSharable, pendingOutboundBytes, register, sendOutboundEvent, shutdown, write
 
- 
 
- 
- 
- 
Method Detail- 
handlerRemovedpublic void handlerRemoved(ChannelHandlerContext ctx) throws Exception Description copied from interface:ChannelHandlerGets called after theChannelHandlerwas removed from the actual context and it doesn't handle events anymore.- Specified by:
- handlerRemovedin interface- ChannelHandler
- Throws:
- Exception
 
 - 
channelInactivepublic void channelInactive(ChannelHandlerContext ctx) throws Exception Description copied from interface:ChannelHandlerTheChannelof theChannelHandlerContextwas registered is now inactive and reached its end of lifetime.- Specified by:
- channelInactivein interface- ChannelHandler
- Throws:
- Exception
 
 - 
readpublic void read(ChannelHandlerContext ctx) Description copied from interface:ChannelHandlerInterceptsChannelHandlerContext.read().- Specified by:
- readin interface- ChannelHandler
 
 - 
channelReadpublic void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception Description copied from interface:ChannelHandlerInvoked when the currentChannelhas read a message from the peer.- Specified by:
- channelReadin interface- ChannelHandler
- Throws:
- Exception
 
 - 
channelReadCompletepublic void channelReadComplete(ChannelHandlerContext ctx) throws Exception Description copied from interface:ChannelHandlerInvoked when the last message read by the current read operation has been consumed byChannelHandler.channelRead(ChannelHandlerContext, Object). IfChannelOption.AUTO_READis off, no further attempt to read an inbound data from the currentChannelwill be made untilChannelHandlerContext.read()is called.- Specified by:
- channelReadCompletein interface- ChannelHandler
- Throws:
- Exception
 
 
- 
 
-