public final class TCPNIOTransport extends NIOTransport implements AsyncQueueEnabledTransport, FilterChainEnabledTransport, TemporarySelectorsEnabledTransport
Transport.State| Modifier and Type | Field and Description |
|---|---|
static ChannelConfigurator |
DEFAULT_CHANNEL_CONFIGURATOR
Default
ChannelConfigurator used to configure client and server side
channels. |
static boolean |
DEFAULT_KEEP_ALIVE |
static int |
DEFAULT_LINGER |
static int |
DEFAULT_SERVER_CONNECTION_BACKLOG |
static boolean |
DEFAULT_TCP_NO_DELAY |
static int |
MAX_RECEIVE_BUFFER_SIZE |
static int |
MAX_SEND_BUFFER_SIZE |
channelConfigurator, DEFAULT_CLIENT_SOCKET_SO_TIMEOUT, DEFAULT_CONNECTION_TIMEOUT, DEFAULT_OPTIMIZED_FOR_MULTIPLEXING, DEFAULT_REUSE_ADDRESS, DEFAULT_SELECTOR_RUNNER_COUNT, DEFAULT_SERVER_SOCKET_SO_TIMEOUT, nioChannelDistributor, selectionKeyHandler, selectorHandler, selectorProvider, selectorRunners, shutdownFuture, shutdownListeners, shutdownService, temporarySelectorIOattributeBuilder, connectionMonitoringConfig, isBlocking, isStandalone, kernelPool, kernelPoolConfig, managedWorkerPool, memoryManager, name, processor, processorSelector, readBufferSize, readTimeout, state, strategy, threadPoolMonitoringConfig, transportMonitoringConfig, workerPoolConfig, workerThreadPool, writeBufferSize, writeTimeoutDEFAULT_READ_BUFFER_SIZE, DEFAULT_READ_TIMEOUT, DEFAULT_WRITE_BUFFER_SIZE, DEFAULT_WRITE_TIMEOUT| Constructor and Description |
|---|
TCPNIOTransport() |
| Modifier and Type | Method and Description |
|---|---|
TCPNIOServerConnection |
bind(int port)
Binds Transport to the specific port on localhost.
|
TCPNIOServerConnection |
bind(SocketAddress socketAddress)
Binds Transport to the specific SocketAddress.
|
TCPNIOServerConnection |
bind(SocketAddress socketAddress,
int backlog)
Binds Transport to the specific SocketAddress.
|
TCPNIOServerConnection |
bind(String host,
int port)
Binds Transport to the specific host and port.
|
TCPNIOServerConnection |
bind(String host,
int port,
int backlog)
Binds Transport to the specific host and port.
|
TCPNIOServerConnection |
bind(String host,
PortRange portRange,
int backlog)
Binds Transport to the specific host, and port within a
PortRange. |
TCPNIOServerConnection |
bindToInherited()
Binds the Transport to the channel inherited from the entity that
created this Java virtual machine.
|
protected void |
closeConnection(Connection connection)
Close the connection, managed by Transport
|
void |
configureStandalone(boolean isStandalone) |
GrizzlyFuture<Connection> |
connect(SocketAddress remoteAddress)
Creates, initializes and connects socket to the specific
SocketAddress and returns Connection, representing socket. |
void |
connect(SocketAddress remoteAddress,
CompletionHandler<Connection> completionHandler)
Creates, initializes and connects socket to the specific
SocketAddress and returns Connection, representing socket. |
GrizzlyFuture<Connection> |
connect(SocketAddress remoteAddress,
SocketAddress localAddress)
Creates, initializes socket, binds it to the specific local and remote
SocketAddress and returns Connection, representing socket. |
void |
connect(SocketAddress remoteAddress,
SocketAddress localAddress,
CompletionHandler<Connection> completionHandler)
Creates, initializes socket, binds it to the specific local and remote
SocketAddress and returns Connection, representing socket. |
GrizzlyFuture<Connection> |
connect(String host,
int port)
Creates, initializes and connects socket to the specific remote host
and port and returns
Connection, representing socket. |
protected Object |
createJmxManagementObject()
Create the Transport JMX management object.
|
protected TemporarySelectorIO |
createTemporarySelectorIO() |
void |
fireIOEvent(IOEvent ioEvent,
Connection connection,
IOEventLifeCycleListener listener)
Fires specific
IOEvent on the Connection |
AsyncQueueIO<SocketAddress> |
getAsyncQueueIO()
Get asynchronous queue implementation.
|
ChannelConfigurator |
getChannelConfigurator() |
protected int |
getDefaultSelectorRunnersCount() |
int |
getLinger() |
Reader<SocketAddress> |
getReader(boolean isBlocking)
Get the
Reader implementation, depending on the requested mode. |
Reader<SocketAddress> |
getReader(Connection connection)
Get the
Reader to read data from the Connection. |
int |
getServerConnectionBackLog()
Get the default server connection backlog size.
|
TemporarySelectorIO |
getTemporarySelectorIO() |
Filter |
getTransportFilter()
Get transport
Filter, which is aware of Transport
specifics; knows how to read/write from/to Transport
specific Connection streams. |
Writer<SocketAddress> |
getWriter(boolean isBlocking)
Get the
Writer implementation, depending on the requested mode. |
Writer<SocketAddress> |
getWriter(Connection connection)
Get the
Writer to write data to the Connection. |
boolean |
isKeepAlive() |
boolean |
isTcpNoDelay() |
protected void |
listen() |
Buffer |
read(Connection connection,
Buffer buffer) |
void |
setKeepAlive(boolean isKeepAlive) |
void |
setLinger(int linger) |
void |
setServerConnectionBackLog(int serverConnectionBackLog)
Set the default server connection backlog size.
|
void |
setTcpNoDelay(boolean tcpNoDelay) |
void |
unbind(Connection connection)
Unbinds bound
Transport connection. |
void |
unbindAll()
Unbinds all bound
Transport connections. |
int |
write(TCPNIOConnection connection,
WritableMessage message) |
int |
write(TCPNIOConnection connection,
WritableMessage message,
WriteResult currentResult) |
addShutdownListener, configureNIOConnection, createShutdownExecutorService, finalizeShutdown, getClientSocketSoTimeout, getConnectionTimeout, getNIOChannelDistributor, getSelectionKeyHandler, getSelectorHandler, getSelectorProvider, getSelectorRunners, getSelectorRunnersCount, getServerSocketSoTimeout, isOptimizedForMultiplexing, isReuseAddress, notifyProbesError, notifyProbesPause, notifyProbesResume, notifyProbesStart, notifyProbesStop, notifyTransportError, pause, resume, setChannelConfigurator, setClientSocketSoTimeout, setConnectionTimeout, setNIOChannelDistributor, setOptimizedForMultiplexing, setReuseAddress, setSelectionKeyHandler, setSelectorHandler, setSelectorProvider, setSelectorRunnersCount, setServerSocketSoTimeout, shutdown, shutdown, shutdownNow, start, startSelectorRunners, stopSelectorRunnersconfigureBlocking, getAttributeBuilder, getConnectionMonitoringConfig, getIOStrategy, getKernelThreadPool, getKernelThreadPoolConfig, getMemoryManager, getMonitoringConfig, getName, getProcessor, getProcessorSelector, getReadBufferSize, getReadTimeout, getState, getThreadPoolMonitoringConfig, getWorkerThreadPool, getWorkerThreadPoolConfig, getWriteBufferSize, getWriteTimeout, isBlocking, isPaused, isStandalone, isStopped, notifyProbesBeforePause, notifyProbesBeforeResume, notifyProbesBeforeStart, notifyProbesBeforeStop, notifyProbesConfigChanged, notifyProbesPause, notifyProbesStop, obtainProcessor, setAttributeBuilder, setIOStrategy, setKernelPool0, setKernelThreadPool, setKernelThreadPoolConfig, setMemoryManager, setName, setProcessor, setProcessorSelector, setReadBufferSize, setReadTimeout, setWorkerThreadPool, setWorkerThreadPool0, setWorkerThreadPoolConfig, setWriteBufferSize, setWriteTimeout, stoppublic static final ChannelConfigurator DEFAULT_CHANNEL_CONFIGURATOR
ChannelConfigurator used to configure client and server side
channels.public static final int MAX_RECEIVE_BUFFER_SIZE
public static final int MAX_SEND_BUFFER_SIZE
public static final boolean DEFAULT_TCP_NO_DELAY
public static final boolean DEFAULT_KEEP_ALIVE
public static final int DEFAULT_LINGER
public static final int DEFAULT_SERVER_CONNECTION_BACKLOG
protected TemporarySelectorIO createTemporarySelectorIO()
createTemporarySelectorIO in class NIOTransportprotected void listen()
listen in class NIOTransportprotected int getDefaultSelectorRunnersCount()
getDefaultSelectorRunnersCount in class NIOTransportpublic TCPNIOServerConnection bind(int port) throws IOException
bind in interface SocketBinderConnectionIOExceptionpublic TCPNIOServerConnection bind(String host, int port) throws IOException
bind in interface SocketBinderhost - the local host the server will bind toConnectionIOExceptionpublic TCPNIOServerConnection bind(String host, int port, int backlog) throws IOException
bind in interface SocketBinderhost - the local host the server will bind tobacklog - the maximum length of the queueConnectionIOExceptionpublic TCPNIOServerConnection bind(SocketAddress socketAddress) throws IOException
bind in interface SocketBindersocketAddress - the local address the server will bind toConnectionIOExceptionpublic TCPNIOServerConnection bind(SocketAddress socketAddress, int backlog) throws IOException
bind in interface SocketBindersocketAddress - the local address the server will bind tobacklog - the maximum length of the queueConnectionIOExceptionpublic TCPNIOServerConnection bindToInherited() throws IOException
bindToInherited in interface SocketBinderConnectionIOExceptionpublic TCPNIOServerConnection bind(String host, PortRange portRange, int backlog) throws IOException
PortRange.bind in interface SocketBinderhost - the local host the server will bind toportRange - PortRange.backlog - the maximum length of the queueConnectionIOExceptionpublic void unbind(Connection connection)
Transport connection.unbind in interface SocketBinderconnection - Connectionpublic void unbindAll()
SocketBinderTransport connections.unbindAll in interface SocketBinderunbindAll in class NIOTransportpublic GrizzlyFuture<Connection> connect(String host, int port)
Connection, representing socket.connect in interface SocketConnectorHandlerhost - remote host to connect to.port - remote port to connect to.GrizzlyFuture of connect operation, which could be used to get
resulting Connection.public GrizzlyFuture<Connection> connect(SocketAddress remoteAddress)
SocketAddress and returns Connection, representing socket.connect in interface ConnectorHandler<SocketAddress>remoteAddress - remote address to connect to.GrizzlyFuture of connect operation, which could be used to get
resulting Connection.public void connect(SocketAddress remoteAddress, CompletionHandler<Connection> completionHandler)
SocketAddress and returns Connection, representing socket.connect in interface ConnectorHandler<SocketAddress>remoteAddress - remote address to connect to.completionHandler - CompletionHandler.public GrizzlyFuture<Connection> connect(SocketAddress remoteAddress, SocketAddress localAddress)
SocketAddress and returns Connection, representing socket.connect in interface ConnectorHandler<SocketAddress>remoteAddress - remote address to connect to.localAddress - local address to bind socket to.GrizzlyFuture of connect operation, which could be used to get
resulting Connection.public void connect(SocketAddress remoteAddress, SocketAddress localAddress, CompletionHandler<Connection> completionHandler)
SocketAddress and returns Connection, representing socket.connect in interface ConnectorHandler<SocketAddress>remoteAddress - remote address to connect to.localAddress - local address to bind socket to.completionHandler - CompletionHandler.protected void closeConnection(Connection connection) throws IOException
AbstractTransportcloseConnection in class NIOTransportIOExceptionpublic ChannelConfigurator getChannelConfigurator()
getChannelConfigurator in class NIOTransportSelectableChannel
configurationpublic AsyncQueueIO<SocketAddress> getAsyncQueueIO()
AsyncQueueEnabledTransportgetAsyncQueueIO in interface AsyncQueueEnabledTransportpublic void configureStandalone(boolean isStandalone)
configureStandalone in interface Transportpublic int getLinger()
public void setLinger(int linger)
public boolean isKeepAlive()
public void setKeepAlive(boolean isKeepAlive)
public boolean isTcpNoDelay()
public void setTcpNoDelay(boolean tcpNoDelay)
public int getServerConnectionBackLog()
public void setServerConnectionBackLog(int serverConnectionBackLog)
serverConnectionBackLog - the default server connection backlog size.public Filter getTransportFilter()
FilterChainEnabledTransportFilter, which is aware of Transport
specifics; knows how to read/write from/to Transport
specific Connection streams.
Each Transport should provide transport Filter
implementation.getTransportFilter in interface FilterChainEnabledTransportFilter, which is aware of Transport
specifics; knows how to read/write from/to Transport
specific Connections.public TemporarySelectorIO getTemporarySelectorIO()
getTemporarySelectorIO in interface TemporarySelectorsEnabledTransportgetTemporarySelectorIO in class NIOTransportpublic void fireIOEvent(IOEvent ioEvent, Connection connection, IOEventLifeCycleListener listener)
TransportIOEvent on the ConnectionfireIOEvent in interface TransportioEvent - I/O eventconnection - Connection, on which we fire the event.listener - I/O event life-cycle listener.public Reader<SocketAddress> getReader(Connection connection)
Reader to read data from the Connection.
The Transport may decide to return blocking or non-blocking Reader
depending on the Connection settings.getReader in interface Transportconnection - Connection.Reader.public Reader<SocketAddress> getReader(boolean isBlocking)
Reader implementation, depending on the requested mode.public Writer<SocketAddress> getWriter(Connection connection)
Writer to write data to the Connection.
The Transport may decide to return blocking or non-blocking Writer
depending on the Connection settings.getWriter in interface Transportconnection - Connection.Writer.public Writer<SocketAddress> getWriter(boolean isBlocking)
Writer implementation, depending on the requested mode.public Buffer read(Connection connection, Buffer buffer) throws IOException
IOExceptionpublic int write(TCPNIOConnection connection, WritableMessage message) throws IOException
IOExceptionpublic int write(TCPNIOConnection connection, WritableMessage message, WriteResult currentResult) throws IOException
IOExceptionprotected Object createJmxManagementObject()
createJmxManagementObject in class AbstractTransportCopyright © 2016 Oracle Corporation. All Rights Reserved.