Allow to specify the used buffer type for ChannelInboundByteBufHandler and ChannelOutboundByteBufHandler by configuration. As default it tries to use a direct ByteBuf

This commit is contained in:
Norman Maurer 2013-03-08 08:20:46 +01:00
parent a9a29bdf3f
commit fd3f923b52
41 changed files with 242 additions and 22 deletions

View File

@ -19,6 +19,7 @@ import io.netty.buffer.ByteBuf;
import io.netty.channel.ChannelDuplexHandler; import io.netty.channel.ChannelDuplexHandler;
import io.netty.channel.ChannelHandler; import io.netty.channel.ChannelHandler;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelHandlerUtil;
import io.netty.channel.ChannelInboundByteHandler; import io.netty.channel.ChannelInboundByteHandler;
import io.netty.channel.ChannelInboundMessageHandler; import io.netty.channel.ChannelInboundMessageHandler;
import io.netty.channel.ChannelPipeline; import io.netty.channel.ChannelPipeline;
@ -63,7 +64,7 @@ public abstract class SpdyOrHttpChooser extends ChannelDuplexHandler implements
@Override @Override
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer(); return ChannelHandlerUtil.allocate(ctx);
} }
@Override @Override

View File

@ -17,6 +17,7 @@ package io.netty.handler.codec;
import io.netty.buffer.ByteBuf; import io.netty.buffer.ByteBuf;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelHandlerUtil;
/** /**
* A decoder that splits the received {@link ByteBuf}s by the fixed number * A decoder that splits the received {@link ByteBuf}s by the fixed number
@ -67,7 +68,7 @@ public class FixedLengthFrameDecoder extends ByteToMessageDecoder {
@Override @Override
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
if (allocateFullBuffer) { if (allocateFullBuffer) {
return ctx.alloc().ioBuffer(frameLength); return ChannelHandlerUtil.allocate(ctx, frameLength);
} else { } else {
return super.newInboundBuffer(ctx); return super.newInboundBuffer(ctx);
} }

View File

@ -20,6 +20,7 @@ import com.yammer.metrics.core.Meter;
import io.netty.buffer.ByteBuf; import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled; import io.netty.buffer.Unpooled;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelHandlerUtil;
import io.netty.channel.ChannelInboundByteHandlerAdapter; import io.netty.channel.ChannelInboundByteHandlerAdapter;
import io.netty.channel.ChannelOption; import io.netty.channel.ChannelOption;
import io.netty.channel.udt.nio.NioUdtProvider; import io.netty.channel.udt.nio.NioUdtProvider;
@ -76,7 +77,7 @@ public class ByteEchoClientHandler extends ChannelInboundByteHandlerAdapter {
@Override @Override
public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx) public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx)
throws Exception { throws Exception {
return ctx.alloc().ioBuffer( return ChannelHandlerUtil.allocate(ctx,
ctx.channel().config().getOption(ChannelOption.SO_RCVBUF)); ctx.channel().config().getOption(ChannelOption.SO_RCVBUF));
} }

View File

@ -18,6 +18,7 @@ package io.netty.example.udt.echo.bytes;
import io.netty.buffer.ByteBuf; import io.netty.buffer.ByteBuf;
import io.netty.channel.ChannelHandler.Sharable; import io.netty.channel.ChannelHandler.Sharable;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelHandlerUtil;
import io.netty.channel.ChannelInboundByteHandlerAdapter; import io.netty.channel.ChannelInboundByteHandlerAdapter;
import io.netty.channel.ChannelOption; import io.netty.channel.ChannelOption;
import io.netty.channel.udt.nio.NioUdtProvider; import io.netty.channel.udt.nio.NioUdtProvider;
@ -57,7 +58,7 @@ public class ByteEchoServerHandler extends ChannelInboundByteHandlerAdapter {
@Override @Override
public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx) public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx)
throws Exception { throws Exception {
return ctx.alloc().ioBuffer( return ChannelHandlerUtil.allocate(ctx,
ctx.channel().config().getOption(ChannelOption.SO_RCVBUF)); ctx.channel().config().getOption(ChannelOption.SO_RCVBUF));
} }

View File

@ -17,6 +17,7 @@ package io.netty.handler.logging;
import io.netty.buffer.ByteBuf; import io.netty.buffer.ByteBuf;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelHandlerUtil;
import io.netty.channel.ChannelInboundByteHandler; import io.netty.channel.ChannelInboundByteHandler;
import io.netty.channel.ChannelOutboundByteHandler; import io.netty.channel.ChannelOutboundByteHandler;
import io.netty.channel.ChannelPromise; import io.netty.channel.ChannelPromise;
@ -108,7 +109,7 @@ public class ByteLoggingHandler
@Override @Override
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer(); return ChannelHandlerUtil.allocate(ctx);
} }
@Override @Override
@ -123,7 +124,7 @@ public class ByteLoggingHandler
@Override @Override
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer(); return ChannelHandlerUtil.allocate(ctx);
} }
@Override @Override

View File

@ -23,6 +23,7 @@ import io.netty.channel.ChannelFlushPromiseNotifier;
import io.netty.channel.ChannelFuture; import io.netty.channel.ChannelFuture;
import io.netty.channel.ChannelFutureListener; import io.netty.channel.ChannelFutureListener;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelHandlerUtil;
import io.netty.channel.ChannelInboundByteHandler; import io.netty.channel.ChannelInboundByteHandler;
import io.netty.channel.ChannelOutboundByteHandler; import io.netty.channel.ChannelOutboundByteHandler;
import io.netty.channel.ChannelPipeline; import io.netty.channel.ChannelPipeline;
@ -380,7 +381,7 @@ public class SslHandler
@Override @Override
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer(); return ChannelHandlerUtil.allocate(ctx);
} }
@Override @Override
@ -395,7 +396,7 @@ public class SslHandler
@Override @Override
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer(); return ChannelHandlerUtil.allocate(ctx);
} }
@Override @Override

View File

@ -21,6 +21,7 @@ import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled; import io.netty.buffer.Unpooled;
import io.netty.channel.Channel; import io.netty.channel.Channel;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelHandlerUtil;
import io.netty.channel.ChannelInboundByteHandlerAdapter; import io.netty.channel.ChannelInboundByteHandlerAdapter;
import io.netty.channel.ChannelInitializer; import io.netty.channel.ChannelInitializer;
import io.netty.channel.sctp.SctpChannel; import io.netty.channel.sctp.SctpChannel;
@ -160,7 +161,7 @@ public class SctpEchoTest extends AbstractSctpTest {
@Override @Override
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer(0, maxInboundBufferSize); return ChannelHandlerUtil.allocate(ctx, 0, maxInboundBufferSize);
} }
@Override @Override

View File

@ -21,6 +21,7 @@ import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled; import io.netty.buffer.Unpooled;
import io.netty.channel.Channel; import io.netty.channel.Channel;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelHandlerUtil;
import io.netty.channel.ChannelInboundByteHandlerAdapter; import io.netty.channel.ChannelInboundByteHandlerAdapter;
import io.netty.channel.ChannelInitializer; import io.netty.channel.ChannelInitializer;
import io.netty.channel.socket.SocketChannel; import io.netty.channel.socket.SocketChannel;
@ -186,7 +187,7 @@ public class SocketEchoTest extends AbstractSocketTest {
@Override @Override
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer(0, maxInboundBufferSize); return ChannelHandlerUtil.allocate(ctx, 0, maxInboundBufferSize);
} }
@Override @Override

View File

@ -195,4 +195,9 @@ final class DefaultRxtxChannelConfig extends DefaultChannelConfig implements Rxt
public RxtxChannelConfig setAutoRead(boolean autoRead) { public RxtxChannelConfig setAutoRead(boolean autoRead) {
return (RxtxChannelConfig) super.setAutoRead(autoRead); return (RxtxChannelConfig) super.setAutoRead(autoRead);
} }
@Override
public RxtxChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
return (RxtxChannelConfig) super.setDefaultHandlerByteBufType(type);
}
} }

View File

@ -269,4 +269,7 @@ public interface RxtxChannelConfig extends ChannelConfig {
@Override @Override
RxtxChannelConfig setAutoRead(boolean autoRead); RxtxChannelConfig setAutoRead(boolean autoRead);
@Override
RxtxChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -19,6 +19,7 @@ package io.netty.channel.sctp;
import com.sun.nio.sctp.SctpChannel; import com.sun.nio.sctp.SctpChannel;
import com.sun.nio.sctp.SctpStandardSocketOptions; import com.sun.nio.sctp.SctpStandardSocketOptions;
import io.netty.buffer.ByteBufAllocator; import io.netty.buffer.ByteBufAllocator;
import io.netty.channel.ChannelConfig;
import io.netty.channel.ChannelException; import io.netty.channel.ChannelException;
import io.netty.channel.ChannelOption; import io.netty.channel.ChannelOption;
import io.netty.channel.DefaultChannelConfig; import io.netty.channel.DefaultChannelConfig;
@ -189,4 +190,9 @@ public class DefaultSctpChannelConfig extends DefaultChannelConfig implements Sc
public SctpChannelConfig setAutoRead(boolean autoRead) { public SctpChannelConfig setAutoRead(boolean autoRead) {
return (SctpChannelConfig) super.setAutoRead(autoRead); return (SctpChannelConfig) super.setAutoRead(autoRead);
} }
@Override
public SctpChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
return (SctpChannelConfig) super.setDefaultHandlerByteBufType(type);
}
} }

View File

@ -173,4 +173,9 @@ public class DefaultSctpServerChannelConfig extends DefaultChannelConfig impleme
public SctpServerChannelConfig setAutoRead(boolean autoRead) { public SctpServerChannelConfig setAutoRead(boolean autoRead) {
return (SctpServerChannelConfig) super.setAutoRead(autoRead); return (SctpServerChannelConfig) super.setAutoRead(autoRead);
} }
@Override
public SctpServerChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
return (SctpServerChannelConfig) super.setDefaultHandlerByteBufType(type);
}
} }

View File

@ -107,4 +107,7 @@ public interface SctpChannelConfig extends ChannelConfig {
@Override @Override
SctpChannelConfig setAutoRead(boolean autoRead); SctpChannelConfig setAutoRead(boolean autoRead);
@Override
SctpChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -102,4 +102,7 @@ public interface SctpServerChannelConfig extends ChannelConfig {
@Override @Override
SctpServerChannelConfig setAutoRead(boolean autoRead); SctpServerChannelConfig setAutoRead(boolean autoRead);
@Override
SctpServerChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -19,6 +19,7 @@ import com.barchart.udt.OptionUDT;
import com.barchart.udt.SocketUDT; import com.barchart.udt.SocketUDT;
import com.barchart.udt.nio.ChannelUDT; import com.barchart.udt.nio.ChannelUDT;
import io.netty.buffer.ByteBufAllocator; import io.netty.buffer.ByteBufAllocator;
import io.netty.channel.ChannelConfig;
import io.netty.channel.ChannelOption; import io.netty.channel.ChannelOption;
import io.netty.channel.DefaultChannelConfig; import io.netty.channel.DefaultChannelConfig;
@ -254,4 +255,10 @@ public class DefaultUdtChannelConfig extends DefaultChannelConfig implements
super.setAutoRead(autoRead); super.setAutoRead(autoRead);
return this; return this;
} }
@Override
public UdtChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
super.setDefaultHandlerByteBufType(type);
return this;
}
} }

View File

@ -157,4 +157,10 @@ public class DefaultUdtServerChannelConfig extends DefaultUdtChannelConfig
super.setAutoRead(autoRead); super.setAutoRead(autoRead);
return this; return this;
} }
@Override
public UdtServerChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
super.setDefaultHandlerByteBufType(type);
return this;
}
} }

View File

@ -162,4 +162,6 @@ public interface UdtChannelConfig extends ChannelConfig {
*/ */
UdtChannelConfig setSystemSendBufferSize(int size); UdtChannelConfig setSystemSendBufferSize(int size);
@Override
UdtChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -80,4 +80,6 @@ public interface UdtServerChannelConfig extends UdtChannelConfig {
@Override @Override
UdtServerChannelConfig setSystemSendBufferSize(int size); UdtServerChannelConfig setSystemSendBufferSize(int size);
@Override
UdtServerChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -20,6 +20,7 @@ import com.yammer.metrics.core.Meter;
import io.netty.buffer.ByteBuf; import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled; import io.netty.buffer.Unpooled;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelHandlerUtil;
import io.netty.channel.ChannelInboundByteHandlerAdapter; import io.netty.channel.ChannelInboundByteHandlerAdapter;
import io.netty.channel.ChannelOption; import io.netty.channel.ChannelOption;
import io.netty.channel.udt.nio.NioUdtProvider; import io.netty.channel.udt.nio.NioUdtProvider;
@ -97,7 +98,7 @@ public class EchoByteHandler extends ChannelInboundByteHandlerAdapter {
@Override @Override
public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx) throws Exception { public ByteBuf newInboundBuffer(final ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer( return ChannelHandlerUtil.allocate(ctx,
ctx.channel().config().getOption(ChannelOption.SO_RCVBUF)); ctx.channel().config().getOption(ChannelOption.SO_RCVBUF));
} }
} }

View File

@ -15,6 +15,7 @@
*/ */
package io.netty.channel; package io.netty.channel;
import io.netty.buffer.ByteBuf;
import io.netty.buffer.ByteBufAllocator; import io.netty.buffer.ByteBufAllocator;
import io.netty.channel.socket.SocketChannelConfig; import io.netty.channel.socket.SocketChannelConfig;
@ -62,6 +63,12 @@ import java.util.Map;
*/ */
public interface ChannelConfig { public interface ChannelConfig {
enum ChannelHandlerByteBufType {
HEAP,
DIRECT,
PREFER_DIRECT
}
/** /**
* Return all set {@link ChannelOption}'s. * Return all set {@link ChannelOption}'s.
*/ */
@ -162,4 +169,23 @@ public interface ChannelConfig {
* need to call it at all. The default value is {@code true}. * need to call it at all. The default value is {@code true}.
*/ */
ChannelConfig setAutoRead(boolean autoRead); ChannelConfig setAutoRead(boolean autoRead);
/**
* Returns the {@link ChannelHandlerByteBufType} which is used to determine what kind of {@link ByteBuf} will
* be created by the {@link ChannelInboundByteHandler#newInboundBuffer(ChannelHandlerContext)} and
* {@link ChannelOutboundByteHandler#newOutboundBuffer(ChannelHandlerContext)} methods.
* <p>
* The implementation of {@link ChannelInboundByteHandler} or {@link ChannelOutboundByteHandler} may still return
* another {@link ByteBuf} if it depends on a special type.
*
* The default is {@link ChannelHandlerByteBufType#PREFER_DIRECT}.
*/
ChannelHandlerByteBufType getDefaultHandlerByteBufType();
/**
* Sets the {@link ChannelHandlerByteBufType} which is used to determine what kind of {@link ByteBuf} will
* be created by the {@link ChannelInboundByteHandler#newInboundBuffer(ChannelHandlerContext)} and
* {@link ChannelOutboundByteHandler#newOutboundBuffer(ChannelHandlerContext)} methods.
*/
ChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -17,6 +17,7 @@
package io.netty.channel; package io.netty.channel;
import io.netty.buffer.BufUtil; import io.netty.buffer.BufUtil;
import io.netty.buffer.ByteBuf;
import io.netty.buffer.MessageBuf; import io.netty.buffer.MessageBuf;
import io.netty.util.Signal; import io.netty.util.Signal;
import io.netty.util.internal.logging.InternalLogger; import io.netty.util.internal.logging.InternalLogger;
@ -151,6 +152,56 @@ public final class ChannelHandlerUtil {
} }
} }
/**
* Allocate a {@link ByteBuf} taking the {@link ChannelConfig#getDefaultHandlerByteBufType()}
* setting into account.
*/
public static ByteBuf allocate(ChannelHandlerContext ctx) {
switch(ctx.channel().config().getDefaultHandlerByteBufType()) {
case DIRECT:
return ctx.alloc().directBuffer();
case PREFER_DIRECT:
return ctx.alloc().ioBuffer();
case HEAP:
return ctx.alloc().heapBuffer();
default:
throw new IllegalStateException();
}
}
/**
* Allocate a {@link ByteBuf} taking the {@link ChannelConfig#getDefaultHandlerByteBufType()}
* setting into account.
*/
public static ByteBuf allocate(ChannelHandlerContext ctx, int initialCapacity) {
switch(ctx.channel().config().getDefaultHandlerByteBufType()) {
case DIRECT:
return ctx.alloc().directBuffer(initialCapacity);
case PREFER_DIRECT:
return ctx.alloc().ioBuffer(initialCapacity);
case HEAP:
return ctx.alloc().heapBuffer(initialCapacity);
default:
throw new IllegalStateException();
}
}
/**
* Allocate a {@link ByteBuf} taking the {@link ChannelConfig#getDefaultHandlerByteBufType()}
* setting into account.
*/
public static ByteBuf allocate(ChannelHandlerContext ctx, int initialCapacity, int maxCapacity) {
switch(ctx.channel().config().getDefaultHandlerByteBufType()) {
case DIRECT:
return ctx.alloc().directBuffer(initialCapacity, maxCapacity);
case PREFER_DIRECT:
return ctx.alloc().ioBuffer(initialCapacity, maxCapacity);
case HEAP:
return ctx.alloc().heapBuffer(initialCapacity, maxCapacity);
default:
throw new IllegalStateException();
}
}
private ChannelHandlerUtil() { } private ChannelHandlerUtil() { }
public interface SingleInboundMessageHandler<T> { public interface SingleInboundMessageHandler<T> {
@ -162,10 +213,10 @@ public final class ChannelHandlerUtil {
boolean acceptInboundMessage(Object msg) throws Exception; boolean acceptInboundMessage(Object msg) throws Exception;
/** /**
* Will get notified once {@link #inboundBufferUpdated(ChannelHandlerContext)} was called. * Will get notified once {@link ChannelStateHandler#inboundBufferUpdated(ChannelHandlerContext)} was called.
* *
* If this method returns {@code false} no further processing of the {@link MessageBuf} * If this method returns {@code false} no further processing of the {@link MessageBuf}
* will be done until the next call of {@link #inboundBufferUpdated(ChannelHandlerContext)}. * will be done until the next call of {@link ChannelStateHandler#inboundBufferUpdated(ChannelHandlerContext)}.
* *
* This will return {@code true} by default, and may get overriden by sub-classes for * This will return {@code true} by default, and may get overriden by sub-classes for
* special handling. * special handling.
@ -201,7 +252,8 @@ public final class ChannelHandlerUtil {
boolean acceptOutboundMessage(Object msg) throws Exception; boolean acceptOutboundMessage(Object msg) throws Exception;
/** /**
* Will get notified once {@link #flush(ChannelHandlerContext, ChannelPromise)} was called. * Will get notified once {@link ChannelOperationHandler#flush(ChannelHandlerContext, ChannelPromise)}
* was called.
* *
* @param ctx the {@link ChannelHandlerContext} which this {@link ChannelHandler} belongs to * @param ctx the {@link ChannelHandlerContext} which this {@link ChannelHandler} belongs to
*/ */
@ -216,7 +268,7 @@ public final class ChannelHandlerUtil {
void flush(ChannelHandlerContext ctx, T msg) throws Exception; void flush(ChannelHandlerContext ctx, T msg) throws Exception;
/** /**
* Is called when {@link #flush(ChannelHandlerContext, ChannelPromise)} returns. * Is called when {@link ChannelOperationHandler#flush(ChannelHandlerContext, ChannelPromise)} returns.
* *
* Super-classes may-override this for special handling. * Super-classes may-override this for special handling.
* *

View File

@ -22,6 +22,12 @@ import io.netty.buffer.ByteBuf;
* *
*/ */
public interface ChannelInboundByteHandler extends ChannelInboundHandler { public interface ChannelInboundByteHandler extends ChannelInboundHandler {
/**
* Return the {@link ByteBuf} which will be used for inbound data for the given {@link ChannelHandlerContext}.
* Implementations should take {@link ChannelConfig#getDefaultHandlerByteBufType()} into account.
* <p>
* Use of {@link ChannelHandlerUtil#allocate(ChannelHandlerContext)} is adviced.
*/
@Override @Override
ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception; ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception;

View File

@ -33,7 +33,7 @@ public abstract class ChannelInboundByteHandlerAdapter
*/ */
@Override @Override
public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newInboundBuffer(ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer(); return ChannelHandlerUtil.allocate(ctx);
} }
@Override @Override

View File

@ -44,7 +44,8 @@ public class ChannelOption<T> extends UniqueName {
new ChannelOption<Boolean>("ALLOW_HALF_CLOSURE"); new ChannelOption<Boolean>("ALLOW_HALF_CLOSURE");
public static final ChannelOption<Boolean> AUTO_READ = public static final ChannelOption<Boolean> AUTO_READ =
new ChannelOption<Boolean>("AUTO_READ"); new ChannelOption<Boolean>("AUTO_READ");
public static final ChannelOption<ChannelConfig.ChannelHandlerByteBufType> DEFAULT_HANDLER_BYTEBUF_TYPE =
new ChannelOption<ChannelConfig.ChannelHandlerByteBufType>("DEFAULT_HANDLER_BYTEBUF_TYPE");
public static final ChannelOption<Boolean> SO_BROADCAST = public static final ChannelOption<Boolean> SO_BROADCAST =
new ChannelOption<Boolean>("SO_BROADCAST"); new ChannelOption<Boolean>("SO_BROADCAST");
public static final ChannelOption<Boolean> SO_KEEPALIVE = public static final ChannelOption<Boolean> SO_KEEPALIVE =

View File

@ -21,6 +21,12 @@ import io.netty.buffer.ByteBuf;
* {@link ChannelOutboundHandler} which operates on bytes which are hold in a {@link ByteBuf}. * {@link ChannelOutboundHandler} which operates on bytes which are hold in a {@link ByteBuf}.
*/ */
public interface ChannelOutboundByteHandler extends ChannelOutboundHandler { public interface ChannelOutboundByteHandler extends ChannelOutboundHandler {
/**
* Return the {@link ByteBuf} which will be used for outbound data for the given {@link ChannelHandlerContext}.
* Implementations should take {@link ChannelConfig#getDefaultHandlerByteBufType()} into account.
* <p>
* Use of {@link ChannelHandlerUtil#allocate(ChannelHandlerContext)} is adviced.
*/
@Override @Override
ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception; ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception;

View File

@ -24,7 +24,7 @@ public abstract class ChannelOutboundByteHandlerAdapter
extends ChannelOperationHandlerAdapter implements ChannelOutboundByteHandler { extends ChannelOperationHandlerAdapter implements ChannelOutboundByteHandler {
@Override @Override
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer(); return ChannelHandlerUtil.allocate(ctx);
} }
@Override @Override

View File

@ -35,6 +35,7 @@ public class DefaultChannelConfig implements ChannelConfig {
protected final Channel channel; protected final Channel channel;
private volatile ChannelHandlerByteBufType handlerByteBufType = ChannelHandlerByteBufType.PREFER_DIRECT;
private volatile ByteBufAllocator allocator = DEFAULT_ALLOCATOR; private volatile ByteBufAllocator allocator = DEFAULT_ALLOCATOR;
private volatile int connectTimeoutMillis = DEFAULT_CONNECT_TIMEOUT; private volatile int connectTimeoutMillis = DEFAULT_CONNECT_TIMEOUT;
private volatile int writeSpinCount = 16; private volatile int writeSpinCount = 16;
@ -49,7 +50,8 @@ public class DefaultChannelConfig implements ChannelConfig {
@Override @Override
public Map<ChannelOption<?>, Object> getOptions() { public Map<ChannelOption<?>, Object> getOptions() {
return getOptions(null, CONNECT_TIMEOUT_MILLIS, WRITE_SPIN_COUNT, ALLOCATOR, AUTO_READ); return getOptions(null, CONNECT_TIMEOUT_MILLIS, WRITE_SPIN_COUNT, ALLOCATOR, AUTO_READ,
DEFAULT_HANDLER_BYTEBUF_TYPE);
} }
protected Map<ChannelOption<?>, Object> getOptions( protected Map<ChannelOption<?>, Object> getOptions(
@ -99,6 +101,9 @@ public class DefaultChannelConfig implements ChannelConfig {
if (option == AUTO_READ) { if (option == AUTO_READ) {
return (T) Boolean.valueOf(isAutoRead()); return (T) Boolean.valueOf(isAutoRead());
} }
if (option == DEFAULT_ALLOCATOR) {
return (T) getDefaultHandlerByteBufType();
}
return null; return null;
} }
@ -115,6 +120,8 @@ public class DefaultChannelConfig implements ChannelConfig {
setAllocator((ByteBufAllocator) value); setAllocator((ByteBufAllocator) value);
} else if (option == AUTO_READ) { } else if (option == AUTO_READ) {
setAutoRead((Boolean) value); setAutoRead((Boolean) value);
} else if (option == DEFAULT_HANDLER_BYTEBUF_TYPE) {
setDefaultHandlerByteBufType((ChannelHandlerByteBufType) value);
} else { } else {
return false; return false;
} }
@ -187,4 +194,15 @@ public class DefaultChannelConfig implements ChannelConfig {
} }
return this; return this;
} }
@Override
public ChannelHandlerByteBufType getDefaultHandlerByteBufType() {
return handlerByteBufType;
}
@Override
public ChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType handlerByteBufType) {
this.handlerByteBufType = handlerByteBufType;
return this;
}
} }

View File

@ -179,4 +179,7 @@ public interface DatagramChannelConfig extends ChannelConfig {
@Override @Override
DatagramChannelConfig setAutoRead(boolean autoRead); DatagramChannelConfig setAutoRead(boolean autoRead);
@Override
DatagramChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -16,6 +16,7 @@
package io.netty.channel.socket; package io.netty.channel.socket;
import io.netty.buffer.ByteBufAllocator; import io.netty.buffer.ByteBufAllocator;
import io.netty.channel.ChannelConfig;
import io.netty.channel.ChannelException; import io.netty.channel.ChannelException;
import io.netty.channel.ChannelOption; import io.netty.channel.ChannelOption;
import io.netty.channel.DefaultChannelConfig; import io.netty.channel.DefaultChannelConfig;
@ -384,4 +385,9 @@ public class DefaultDatagramChannelConfig extends DefaultChannelConfig implement
public DatagramChannelConfig setAutoRead(boolean autoRead) { public DatagramChannelConfig setAutoRead(boolean autoRead) {
return (DatagramChannelConfig) super.setAutoRead(autoRead); return (DatagramChannelConfig) super.setAutoRead(autoRead);
} }
@Override
public DatagramChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
return (DatagramChannelConfig) super.setDefaultHandlerByteBufType(type);
}
} }

View File

@ -162,4 +162,9 @@ public class DefaultServerSocketChannelConfig extends DefaultChannelConfig
public ServerSocketChannelConfig setAutoRead(boolean autoRead) { public ServerSocketChannelConfig setAutoRead(boolean autoRead) {
return (ServerSocketChannelConfig) super.setAutoRead(autoRead); return (ServerSocketChannelConfig) super.setAutoRead(autoRead);
} }
@Override
public ServerSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
return (ServerSocketChannelConfig) super.setDefaultHandlerByteBufType(type);
}
} }

View File

@ -16,6 +16,7 @@
package io.netty.channel.socket; package io.netty.channel.socket;
import io.netty.buffer.ByteBufAllocator; import io.netty.buffer.ByteBufAllocator;
import io.netty.channel.ChannelConfig;
import io.netty.channel.ChannelException; import io.netty.channel.ChannelException;
import io.netty.channel.ChannelOption; import io.netty.channel.ChannelOption;
import io.netty.channel.DefaultChannelConfig; import io.netty.channel.DefaultChannelConfig;
@ -296,4 +297,9 @@ public class DefaultSocketChannelConfig extends DefaultChannelConfig
public SocketChannelConfig setAutoRead(boolean autoRead) { public SocketChannelConfig setAutoRead(boolean autoRead) {
return (SocketChannelConfig) super.setAutoRead(autoRead); return (SocketChannelConfig) super.setAutoRead(autoRead);
} }
@Override
public SocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
return (SocketChannelConfig) super.setDefaultHandlerByteBufType(type);
}
} }

View File

@ -93,4 +93,7 @@ public interface ServerSocketChannelConfig extends ChannelConfig {
@Override @Override
ServerSocketChannelConfig setAutoRead(boolean autoRead); ServerSocketChannelConfig setAutoRead(boolean autoRead);
@Override
ServerSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -17,9 +17,9 @@ package io.netty.channel.socket;
import io.netty.buffer.ByteBufAllocator; import io.netty.buffer.ByteBufAllocator;
import io.netty.channel.ChannelConfig; import io.netty.channel.ChannelConfig;
import io.netty.channel.ChannelHandler;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelOption; import io.netty.channel.ChannelOption;
import io.netty.channel.ChannelStateHandler;
import java.net.Socket; import java.net.Socket;
import java.net.StandardSocketOptions; import java.net.StandardSocketOptions;
@ -148,7 +148,8 @@ public interface SocketChannelConfig extends ChannelConfig {
/** /**
* Sets whether the channel should not close itself when its remote peer shuts down output to * Sets whether the channel should not close itself when its remote peer shuts down output to
* make the connection half-closed. If {@code true} the connection is not closed when the * make the connection half-closed. If {@code true} the connection is not closed when the
* remote peer shuts down output. Instead, {@link ChannelHandler#userEventTriggered(ChannelHandlerContext, Object)} * remote peer shuts down output. Instead,
* {@link ChannelStateHandler#userEventTriggered(ChannelHandlerContext, Object)}
* is invoked with a {@link ChannelInputShutdownEvent} object. If {@code false}, the connection * is invoked with a {@link ChannelInputShutdownEvent} object. If {@code false}, the connection
* is closed automatically. * is closed automatically.
*/ */
@ -165,4 +166,7 @@ public interface SocketChannelConfig extends ChannelConfig {
@Override @Override
SocketChannelConfig setAutoRead(boolean autoRead); SocketChannelConfig setAutoRead(boolean autoRead);
@Override
SocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -223,4 +223,10 @@ final class AioServerSocketChannelConfig extends DefaultChannelConfig implements
super.setAutoRead(autoRead); super.setAutoRead(autoRead);
return this; return this;
} }
@Override
public ServerSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
super.setDefaultHandlerByteBufType(type);
return this;
}
} }

View File

@ -111,4 +111,7 @@ public interface AioSocketChannelConfig extends SocketChannelConfig {
@Override @Override
AioSocketChannelConfig setAutoRead(boolean autoRead); AioSocketChannelConfig setAutoRead(boolean autoRead);
@Override
AioSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -356,4 +356,9 @@ final class DefaultAioSocketChannelConfig extends DefaultChannelConfig
public AioSocketChannelConfig setAutoRead(boolean autoRead) { public AioSocketChannelConfig setAutoRead(boolean autoRead) {
return (AioSocketChannelConfig) super.setAutoRead(autoRead); return (AioSocketChannelConfig) super.setAutoRead(autoRead);
} }
@Override
public AioSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
return (AioSocketChannelConfig) super.setDefaultHandlerByteBufType(type);
}
} }

View File

@ -130,4 +130,10 @@ public class DefaultOioServerSocketChannelConfig extends DefaultServerSocketChan
super.setAutoRead(autoRead); super.setAutoRead(autoRead);
return this; return this;
} }
@Override
public OioServerSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
super.setDefaultHandlerByteBufType(type);
return this;
}
} }

View File

@ -158,4 +158,10 @@ public class DefaultOioSocketChannelConfig extends DefaultSocketChannelConfig im
super.setAutoRead(autoRead); super.setAutoRead(autoRead);
return this; return this;
} }
@Override
public OioSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type) {
super.setDefaultHandlerByteBufType(type);
return this;
}
} }

View File

@ -72,4 +72,7 @@ public interface OioServerSocketChannelConfig extends ServerSocketChannelConfig
@Override @Override
OioServerSocketChannelConfig setAutoRead(boolean autoRead); OioServerSocketChannelConfig setAutoRead(boolean autoRead);
@Override
OioServerSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -87,4 +87,7 @@ public interface OioSocketChannelConfig extends SocketChannelConfig {
@Override @Override
OioSocketChannelConfig setAutoRead(boolean autoRead); OioSocketChannelConfig setAutoRead(boolean autoRead);
@Override
OioSocketChannelConfig setDefaultHandlerByteBufType(ChannelHandlerByteBufType type);
} }

View File

@ -22,6 +22,7 @@ import io.netty.buffer.Unpooled;
import io.netty.channel.Channel; import io.netty.channel.Channel;
import io.netty.channel.ChannelDuplexHandler; import io.netty.channel.ChannelDuplexHandler;
import io.netty.channel.ChannelHandlerContext; import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.ChannelHandlerUtil;
import io.netty.channel.ChannelInboundByteHandler; import io.netty.channel.ChannelInboundByteHandler;
import io.netty.channel.ChannelInboundMessageHandler; import io.netty.channel.ChannelInboundMessageHandler;
import io.netty.channel.ChannelInboundMessageHandlerAdapter; import io.netty.channel.ChannelInboundMessageHandlerAdapter;
@ -413,7 +414,7 @@ public class LocalTransportThreadModelTest {
@Override @Override
public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception { public ByteBuf newOutboundBuffer(ChannelHandlerContext ctx) throws Exception {
return ctx.alloc().ioBuffer(); return ChannelHandlerUtil.allocate(ctx);
} }
@Override @Override