Package io.netty.channel.epoll
Class EpollServerSocketChannelConfig
- java.lang.Object
-
- io.netty.channel.DefaultChannelConfig
-
- io.netty.channel.epoll.EpollChannelConfig
-
- io.netty.channel.epoll.EpollServerChannelConfig
-
- io.netty.channel.epoll.EpollServerSocketChannelConfig
-
- All Implemented Interfaces:
ChannelConfig,ServerSocketChannelConfig
public final class EpollServerSocketChannelConfig extends EpollServerChannelConfig implements ServerSocketChannelConfig
-
-
Field Summary
-
Fields inherited from class io.netty.channel.DefaultChannelConfig
channel
-
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description <T> TgetOption(ChannelOption<T> option)Return the value of the givenChannelOptionjava.util.Map<ChannelOption<?>,java.lang.Object>getOptions()Return all setChannelOption's.intgetTcpDeferAccept()Returns a positive value if TCP_DEFER_ACCEPT is enabled.booleanisFreeBind()booleanisIpTransparent()booleanisReusePort()Returnstrueif the SO_REUSEPORT option is set.EpollServerSocketChannelConfigsetAllocator(ByteBufAllocator allocator)Set theByteBufAllocatorwhich is used for the channel to allocate buffers.EpollServerSocketChannelConfigsetAutoRead(boolean autoRead)Sets ifChannelHandlerContext.read()will be invoked automatically so that a user application doesn't need to call it at all.EpollServerSocketChannelConfigsetBacklog(int backlog)Sets the backlog value to specify when the channel binds to a local address.EpollServerSocketChannelConfigsetConnectTimeoutMillis(int connectTimeoutMillis)Sets the connect timeout of the channel in milliseconds.EpollServerSocketChannelConfigsetFreeBind(boolean freeBind)EpollServerSocketChannelConfigsetIpTransparent(boolean transparent)EpollServerSocketChannelConfigsetMaxMessagesPerRead(int maxMessagesPerRead)Deprecated.EpollServerSocketChannelConfigsetMessageSizeEstimator(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.EpollServerSocketChannelConfigsetPerformancePreferences(int connectionTime, int latency, int bandwidth)Sets the performance preferences as specified inServerSocket.setPerformancePreferences(int, int, int).EpollServerSocketChannelConfigsetReceiveBufferSize(int receiveBufferSize)Gets theStandardSocketOptions.SO_SNDBUFoption.EpollServerSocketChannelConfigsetRecvByteBufAllocator(RecvByteBufAllocator allocator)Set theRecvByteBufAllocatorwhich is used for the channel to allocate receive buffers.EpollServerSocketChannelConfigsetReuseAddress(boolean reuseAddress)Sets theStandardSocketOptions.SO_REUSEADDRoption.EpollServerSocketChannelConfigsetReusePort(boolean reusePort)Set the SO_REUSEPORT option on the underlying Channel.EpollServerSocketChannelConfigsetTcpDeferAccept(int deferAccept)Set theTCP_DEFER_ACCEPToption on the socket.EpollServerSocketChannelConfigsetTcpMd5Sig(java.util.Map<java.net.InetAddress,byte[]> keys)Set theTCP_MD5SIGoption on the socket.EpollServerSocketChannelConfigsetWriteBufferHighWaterMark(int writeBufferHighWaterMark)Deprecated.EpollServerSocketChannelConfigsetWriteBufferLowWaterMark(int writeBufferLowWaterMark)Deprecated.EpollServerSocketChannelConfigsetWriteBufferWaterMark(WriteBufferWaterMark writeBufferWaterMark)Set theWriteBufferWaterMarkwhich is used for setting the high and low water mark of the write buffer.EpollServerSocketChannelConfigsetWriteSpinCount(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.epoll.EpollServerChannelConfig
getBacklog, getReceiveBufferSize, getTcpFastopen, isReuseAddress, setEpollMode, setTcpFastopen
-
Methods inherited from class io.netty.channel.epoll.EpollChannelConfig
autoReadCleared, getEpollMode, getMaxBytesPerGatheringWrite, setMaxBytesPerGatheringWrite, socket
-
Methods inherited from class io.netty.channel.DefaultChannelConfig
getAllocator, getConnectTimeoutMillis, getMaxMessagesPerRead, getMaxMessagesPerWrite, getMessageSizeEstimator, getOptions, getRecvByteBufAllocator, getWriteBufferHighWaterMark, getWriteBufferLowWaterMark, getWriteBufferWaterMark, getWriteSpinCount, isAutoClose, isAutoRead, setAutoClose, 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, setAutoClose, setOptions
-
Methods inherited from interface io.netty.channel.socket.ServerSocketChannelConfig
getBacklog, getReceiveBufferSize, isReuseAddress
-
-
-
-
Method Detail
-
getOptions
public java.util.Map<ChannelOption<?>,java.lang.Object> getOptions()
Description copied from interface:ChannelConfigReturn all setChannelOption's.- Specified by:
getOptionsin interfaceChannelConfig- Overrides:
getOptionsin classEpollServerChannelConfig
-
getOption
public <T> T getOption(ChannelOption<T> option)
Description copied from interface:ChannelConfigReturn the value of the givenChannelOption- Specified by:
getOptionin interfaceChannelConfig- Overrides:
getOptionin classEpollServerChannelConfig
-
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 classEpollServerChannelConfig- Returns:
trueif and only if the property has been set
-
setReuseAddress
public EpollServerSocketChannelConfig setReuseAddress(boolean reuseAddress)
Description copied from interface:ServerSocketChannelConfigSets theStandardSocketOptions.SO_REUSEADDRoption.- Specified by:
setReuseAddressin interfaceServerSocketChannelConfig- Overrides:
setReuseAddressin classEpollServerChannelConfig
-
setReceiveBufferSize
public EpollServerSocketChannelConfig setReceiveBufferSize(int receiveBufferSize)
Description copied from interface:ServerSocketChannelConfigGets theStandardSocketOptions.SO_SNDBUFoption.- Specified by:
setReceiveBufferSizein interfaceServerSocketChannelConfig- Overrides:
setReceiveBufferSizein classEpollServerChannelConfig
-
setPerformancePreferences
public EpollServerSocketChannelConfig setPerformancePreferences(int connectionTime, int latency, int bandwidth)
Description copied from interface:ServerSocketChannelConfigSets the performance preferences as specified inServerSocket.setPerformancePreferences(int, int, int).- Specified by:
setPerformancePreferencesin interfaceServerSocketChannelConfig- Overrides:
setPerformancePreferencesin classEpollServerChannelConfig
-
setBacklog
public EpollServerSocketChannelConfig setBacklog(int backlog)
Description copied from interface:ServerSocketChannelConfigSets the backlog value to specify when the channel binds to a local address.- Specified by:
setBacklogin interfaceServerSocketChannelConfig- Overrides:
setBacklogin classEpollServerChannelConfig
-
setConnectTimeoutMillis
public EpollServerSocketChannelConfig 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- Specified by:
setConnectTimeoutMillisin interfaceServerSocketChannelConfig- Overrides:
setConnectTimeoutMillisin classEpollServerChannelConfig- Parameters:
connectTimeoutMillis- the connect timeout in milliseconds.0to disable.
-
setMaxMessagesPerRead
@Deprecated public EpollServerSocketChannelConfig setMaxMessagesPerRead(int maxMessagesPerRead)
Deprecated.Description copied from class:DefaultChannelConfig- Specified by:
setMaxMessagesPerReadin interfaceChannelConfig- Specified by:
setMaxMessagesPerReadin interfaceServerSocketChannelConfig- Overrides:
setMaxMessagesPerReadin classEpollServerChannelConfig
-
setWriteSpinCount
public EpollServerSocketChannelConfig 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 interfaceServerSocketChannelConfig- Overrides:
setWriteSpinCountin classEpollServerChannelConfig
-
setAllocator
public EpollServerSocketChannelConfig setAllocator(ByteBufAllocator allocator)
Description copied from interface:ChannelConfigSet theByteBufAllocatorwhich is used for the channel to allocate buffers.- Specified by:
setAllocatorin interfaceChannelConfig- Specified by:
setAllocatorin interfaceServerSocketChannelConfig- Overrides:
setAllocatorin classEpollServerChannelConfig
-
setRecvByteBufAllocator
public EpollServerSocketChannelConfig 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 interfaceServerSocketChannelConfig- Overrides:
setRecvByteBufAllocatorin classEpollServerChannelConfig
-
setAutoRead
public EpollServerSocketChannelConfig 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 interfaceServerSocketChannelConfig- Overrides:
setAutoReadin classEpollServerChannelConfig
-
setWriteBufferHighWaterMark
@Deprecated public EpollServerSocketChannelConfig setWriteBufferHighWaterMark(int writeBufferHighWaterMark)
Deprecated.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- Specified by:
setWriteBufferHighWaterMarkin interfaceServerSocketChannelConfig- Overrides:
setWriteBufferHighWaterMarkin classEpollServerChannelConfig
-
setWriteBufferLowWaterMark
@Deprecated public EpollServerSocketChannelConfig setWriteBufferLowWaterMark(int writeBufferLowWaterMark)
Deprecated.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- Specified by:
setWriteBufferLowWaterMarkin interfaceServerSocketChannelConfig- Overrides:
setWriteBufferLowWaterMarkin classEpollServerChannelConfig
-
setWriteBufferWaterMark
public EpollServerSocketChannelConfig 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 interfaceServerSocketChannelConfig- Overrides:
setWriteBufferWaterMarkin classEpollServerChannelConfig
-
setMessageSizeEstimator
public EpollServerSocketChannelConfig 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 interfaceServerSocketChannelConfig- Overrides:
setMessageSizeEstimatorin classEpollServerChannelConfig
-
setTcpMd5Sig
public EpollServerSocketChannelConfig setTcpMd5Sig(java.util.Map<java.net.InetAddress,byte[]> keys)
Set theTCP_MD5SIGoption on the socket. Seelinux/tcp.hfor more details. Keys can only be set on, not read to prevent a potential leak, as they are confidential. Allowing them being read would mean anyone with access to the channel could get them.
-
isReusePort
public boolean isReusePort()
Returnstrueif the SO_REUSEPORT option is set.
-
setReusePort
public EpollServerSocketChannelConfig setReusePort(boolean reusePort)
Set the SO_REUSEPORT option on the underlying Channel. This will allow to bind multipleEpollSocketChannels to the same port and so accept connections with multiple threads. Be aware this method needs be called beforeChannel.bind(java.net.SocketAddress)to have any affect.
-
isFreeBind
public boolean isFreeBind()
-
setFreeBind
public EpollServerSocketChannelConfig setFreeBind(boolean freeBind)
-
isIpTransparent
public boolean isIpTransparent()
-
setIpTransparent
public EpollServerSocketChannelConfig setIpTransparent(boolean transparent)
-
setTcpDeferAccept
public EpollServerSocketChannelConfig setTcpDeferAccept(int deferAccept)
Set theTCP_DEFER_ACCEPToption on the socket. Seeman 7 tcpfor more details.
-
getTcpDeferAccept
public int getTcpDeferAccept()
Returns a positive value if TCP_DEFER_ACCEPT is enabled.
-
-