Package io.netty.channel.socket.nio
Class NioDomainSocketChannel.NioDomainSocketChannelConfig
- java.lang.Object
-
- io.netty.channel.DefaultChannelConfig
-
- io.netty.channel.socket.nio.NioDomainSocketChannel.NioDomainSocketChannelConfig
-
- All Implemented Interfaces:
ChannelConfig,DuplexChannelConfig
- Enclosing class:
- NioDomainSocketChannel
private final class NioDomainSocketChannel.NioDomainSocketChannelConfig extends DefaultChannelConfig implements DuplexChannelConfig
-
-
Field Summary
Fields Modifier and Type Field Description private booleanallowHalfClosureprivate java.nio.channels.SocketChanneljavaChannelprivate intmaxBytesPerGatheringWrite-
Fields inherited from class io.netty.channel.DefaultChannelConfig
channel
-
-
Constructor Summary
Constructors Modifier Constructor Description privateNioDomainSocketChannelConfig(NioDomainSocketChannel channel, java.nio.channels.SocketChannel javaChannel)
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description protected voidautoReadCleared()Is called onceDefaultChannelConfig.setAutoRead(boolean)is called withfalseandDefaultChannelConfig.isAutoRead()wastruebefore.private voidcalculateMaxBytesPerGatheringWrite()(package private) intgetMaxBytesPerGatheringWrite()<T> TgetOption(ChannelOption<T> option)Return the value of the givenChannelOptionjava.util.Map<ChannelOption<?>,java.lang.Object>getOptions()Return all setChannelOption's.private intgetReceiveBufferSize()private intgetSendBufferSize()booleanisAllowHalfClosure()Returnstrueif and only if the channel should not close itself when its remote peer shuts down output to make the connection half-closed.private java.nio.channels.SocketChanneljdkChannel()NioDomainSocketChannel.NioDomainSocketChannelConfigsetAllocator(ByteBufAllocator allocator)Set theByteBufAllocatorwhich is used for the channel to allocate buffers.NioDomainSocketChannel.NioDomainSocketChannelConfigsetAllowHalfClosure(boolean allowHalfClosure)Sets whether the channel should not close itself when its remote peer shuts down output to make the connection half-closed.NioDomainSocketChannel.NioDomainSocketChannelConfigsetAutoClose(boolean autoClose)Sets whether theChannelshould be closed automatically and immediately on write failure.NioDomainSocketChannel.NioDomainSocketChannelConfigsetAutoRead(boolean autoRead)Sets ifChannelHandlerContext.read()will be invoked automatically so that a user application doesn't need to call it at all.NioDomainSocketChannel.NioDomainSocketChannelConfigsetConnectTimeoutMillis(int connectTimeoutMillis)Sets the connect timeout of the channel in milliseconds.(package private) voidsetMaxBytesPerGatheringWrite(int maxBytesPerGatheringWrite)NioDomainSocketChannel.NioDomainSocketChannelConfigsetMaxMessagesPerRead(int maxMessagesPerRead)Deprecated.NioDomainSocketChannel.NioDomainSocketChannelConfigsetMessageSizeEstimator(MessageSizeEstimator estimator)Set theMessageSizeEstimatorwhich is used for the channel to detect the size of a message.<T> booleansetOption(ChannelOption<T> option, T value)Sets a configuration property with the specified name and value.private NioDomainSocketChannel.NioDomainSocketChannelConfigsetReceiveBufferSize(int receiveBufferSize)NioDomainSocketChannel.NioDomainSocketChannelConfigsetRecvByteBufAllocator(RecvByteBufAllocator allocator)Set theRecvByteBufAllocatorwhich is used for the channel to allocate receive buffers.private NioDomainSocketChannel.NioDomainSocketChannelConfigsetSendBufferSize(int sendBufferSize)NioDomainSocketChannel.NioDomainSocketChannelConfigsetWriteBufferHighWaterMark(int writeBufferHighWaterMark)Sets the high water mark of the write buffer.NioDomainSocketChannel.NioDomainSocketChannelConfigsetWriteBufferLowWaterMark(int writeBufferLowWaterMark)Sets the low water mark of the write buffer.NioDomainSocketChannel.NioDomainSocketChannelConfigsetWriteBufferWaterMark(WriteBufferWaterMark writeBufferWaterMark)Set theWriteBufferWaterMarkwhich is used for setting the high and low water mark of the write buffer.NioDomainSocketChannel.NioDomainSocketChannelConfigsetWriteSpinCount(int writeSpinCount)Sets the maximum loop count for a write operation untilWritableByteChannel.write(ByteBuffer)returns a non-zero value.-
Methods inherited from class io.netty.channel.DefaultChannelConfig
getAllocator, getConnectTimeoutMillis, getMaxMessagesPerRead, getMaxMessagesPerWrite, getMessageSizeEstimator, getOptions, getRecvByteBufAllocator, getWriteBufferHighWaterMark, getWriteBufferLowWaterMark, getWriteBufferWaterMark, getWriteSpinCount, isAutoClose, isAutoRead, setMaxMessagesPerWrite, setOptions, validate
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface io.netty.channel.ChannelConfig
getAllocator, getConnectTimeoutMillis, getMaxMessagesPerRead, getMessageSizeEstimator, getRecvByteBufAllocator, getWriteBufferHighWaterMark, getWriteBufferLowWaterMark, getWriteBufferWaterMark, getWriteSpinCount, isAutoClose, isAutoRead, setOptions
-
-
-
-
Constructor Detail
-
NioDomainSocketChannelConfig
private NioDomainSocketChannelConfig(NioDomainSocketChannel channel, java.nio.channels.SocketChannel javaChannel)
-
-
Method Detail
-
isAllowHalfClosure
public boolean isAllowHalfClosure()
Description copied from interface:DuplexChannelConfigReturnstrueif and only if the channel should not close itself when its remote peer shuts down output to make the connection half-closed. Iffalse, the connection is closed automatically when the remote peer shuts down output.- Specified by:
isAllowHalfClosurein interfaceDuplexChannelConfig
-
setAllowHalfClosure
public NioDomainSocketChannel.NioDomainSocketChannelConfig setAllowHalfClosure(boolean allowHalfClosure)
Description copied from interface:DuplexChannelConfigSets whether the channel should not close itself when its remote peer shuts down output to make the connection half-closed. Iftruethe connection is not closed when the remote peer shuts down output. Instead,ChannelInboundHandler.userEventTriggered(ChannelHandlerContext, Object)is invoked with aChannelInputShutdownEventobject. Iffalse, the connection is closed automatically.- Specified by:
setAllowHalfClosurein interfaceDuplexChannelConfig
-
getOptions
public java.util.Map<ChannelOption<?>,java.lang.Object> getOptions()
Description copied from interface:ChannelConfigReturn all setChannelOption's.- Specified by:
getOptionsin interfaceChannelConfig- Overrides:
getOptionsin classDefaultChannelConfig
-
getOption
public <T> T getOption(ChannelOption<T> option)
Description copied from interface:ChannelConfigReturn the value of the givenChannelOption- Specified by:
getOptionin interfaceChannelConfig- Overrides:
getOptionin classDefaultChannelConfig
-
setOption
public <T> boolean setOption(ChannelOption<T> option, T value)
Description copied from interface:ChannelConfigSets a configuration property with the specified name and value. To override this method properly, you must call the super class:public boolean setOption(ChannelOption<T> option, T value) { if (super.setOption(option, value)) { return true; } if (option.equals(additionalOption)) { .... return true; } return false; }- Specified by:
setOptionin interfaceChannelConfig- Overrides:
setOptionin classDefaultChannelConfig- Returns:
trueif and only if the property has been set
-
getReceiveBufferSize
private int getReceiveBufferSize()
-
setReceiveBufferSize
private NioDomainSocketChannel.NioDomainSocketChannelConfig setReceiveBufferSize(int receiveBufferSize)
-
getSendBufferSize
private int getSendBufferSize()
-
setSendBufferSize
private NioDomainSocketChannel.NioDomainSocketChannelConfig setSendBufferSize(int sendBufferSize)
-
setConnectTimeoutMillis
public NioDomainSocketChannel.NioDomainSocketChannelConfig setConnectTimeoutMillis(int connectTimeoutMillis)
Description copied from interface:ChannelConfigSets the connect timeout of the channel in milliseconds. If theChanneldoes not support connect operation, this property is not used at all, and therefore will be ignored.- Specified by:
setConnectTimeoutMillisin interfaceChannelConfig- Overrides:
setConnectTimeoutMillisin classDefaultChannelConfig- Parameters:
connectTimeoutMillis- the connect timeout in milliseconds.0to disable.
-
setMaxMessagesPerRead
@Deprecated public NioDomainSocketChannel.NioDomainSocketChannelConfig setMaxMessagesPerRead(int maxMessagesPerRead)
Deprecated.Description copied from class:DefaultChannelConfig- Specified by:
setMaxMessagesPerReadin interfaceChannelConfig- Specified by:
setMaxMessagesPerReadin interfaceDuplexChannelConfig- Overrides:
setMaxMessagesPerReadin classDefaultChannelConfig
-
setWriteSpinCount
public NioDomainSocketChannel.NioDomainSocketChannelConfig setWriteSpinCount(int writeSpinCount)
Description copied from interface:ChannelConfigSets the maximum loop count for a write operation untilWritableByteChannel.write(ByteBuffer)returns a non-zero value. It is similar to what a spin lock is used for in concurrency programming. It improves memory utilization and write throughput depending on the platform that JVM runs on. The default value is16.- Specified by:
setWriteSpinCountin interfaceChannelConfig- Specified by:
setWriteSpinCountin interfaceDuplexChannelConfig- Overrides:
setWriteSpinCountin classDefaultChannelConfig
-
setAllocator
public NioDomainSocketChannel.NioDomainSocketChannelConfig setAllocator(ByteBufAllocator allocator)
Description copied from interface:ChannelConfigSet theByteBufAllocatorwhich is used for the channel to allocate buffers.- Specified by:
setAllocatorin interfaceChannelConfig- Specified by:
setAllocatorin interfaceDuplexChannelConfig- Overrides:
setAllocatorin classDefaultChannelConfig
-
setRecvByteBufAllocator
public NioDomainSocketChannel.NioDomainSocketChannelConfig setRecvByteBufAllocator(RecvByteBufAllocator allocator)
Description copied from interface:ChannelConfigSet theRecvByteBufAllocatorwhich is used for the channel to allocate receive buffers.- Specified by:
setRecvByteBufAllocatorin interfaceChannelConfig- Specified by:
setRecvByteBufAllocatorin interfaceDuplexChannelConfig- Overrides:
setRecvByteBufAllocatorin classDefaultChannelConfig
-
setAutoRead
public NioDomainSocketChannel.NioDomainSocketChannelConfig setAutoRead(boolean autoRead)
Description copied from interface:ChannelConfigSets ifChannelHandlerContext.read()will be invoked automatically so that a user application doesn't need to call it at all. The default value istrue.- Specified by:
setAutoReadin interfaceChannelConfig- Specified by:
setAutoReadin interfaceDuplexChannelConfig- Overrides:
setAutoReadin classDefaultChannelConfig
-
setAutoClose
public NioDomainSocketChannel.NioDomainSocketChannelConfig setAutoClose(boolean autoClose)
Description copied from interface:ChannelConfigSets whether theChannelshould be closed automatically and immediately on write failure. The default istrue.- Specified by:
setAutoClosein interfaceChannelConfig- Specified by:
setAutoClosein interfaceDuplexChannelConfig- Overrides:
setAutoClosein classDefaultChannelConfig
-
setWriteBufferHighWaterMark
public NioDomainSocketChannel.NioDomainSocketChannelConfig setWriteBufferHighWaterMark(int writeBufferHighWaterMark)
Description copied from interface:ChannelConfigSets the high water mark of the write buffer. If the number of bytes queued in the write buffer exceeds this value,
Channel.isWritable()will start to returnfalse.- Specified by:
setWriteBufferHighWaterMarkin interfaceChannelConfig- Overrides:
setWriteBufferHighWaterMarkin classDefaultChannelConfig
-
setWriteBufferLowWaterMark
public NioDomainSocketChannel.NioDomainSocketChannelConfig setWriteBufferLowWaterMark(int writeBufferLowWaterMark)
Description copied from interface:ChannelConfigSets the low water mark of the write buffer. Once the number of bytes queued in the write buffer exceeded the high water mark and then dropped down below this value,
Channel.isWritable()will start to returntrueagain.- Specified by:
setWriteBufferLowWaterMarkin interfaceChannelConfig- Overrides:
setWriteBufferLowWaterMarkin classDefaultChannelConfig
-
setWriteBufferWaterMark
public NioDomainSocketChannel.NioDomainSocketChannelConfig setWriteBufferWaterMark(WriteBufferWaterMark writeBufferWaterMark)
Description copied from interface:ChannelConfigSet theWriteBufferWaterMarkwhich is used for setting the high and low water mark of the write buffer.- Specified by:
setWriteBufferWaterMarkin interfaceChannelConfig- Specified by:
setWriteBufferWaterMarkin interfaceDuplexChannelConfig- Overrides:
setWriteBufferWaterMarkin classDefaultChannelConfig
-
setMessageSizeEstimator
public NioDomainSocketChannel.NioDomainSocketChannelConfig setMessageSizeEstimator(MessageSizeEstimator estimator)
Description copied from interface:ChannelConfigSet theMessageSizeEstimatorwhich is used for the channel to detect the size of a message.- Specified by:
setMessageSizeEstimatorin interfaceChannelConfig- Specified by:
setMessageSizeEstimatorin interfaceDuplexChannelConfig- Overrides:
setMessageSizeEstimatorin classDefaultChannelConfig
-
autoReadCleared
protected void autoReadCleared()
Description copied from class:DefaultChannelConfigIs called onceDefaultChannelConfig.setAutoRead(boolean)is called withfalseandDefaultChannelConfig.isAutoRead()wastruebefore.- Overrides:
autoReadClearedin classDefaultChannelConfig
-
setMaxBytesPerGatheringWrite
void setMaxBytesPerGatheringWrite(int maxBytesPerGatheringWrite)
-
getMaxBytesPerGatheringWrite
int getMaxBytesPerGatheringWrite()
-
calculateMaxBytesPerGatheringWrite
private void calculateMaxBytesPerGatheringWrite()
-
jdkChannel
private java.nio.channels.SocketChannel jdkChannel()
-
-