public abstract class AbstractEpollStreamChannel extends AbstractChannel implements DuplexChannel
Modifier and Type | Class and Description |
---|---|
protected class |
AbstractEpollStreamChannel.SpliceInTask |
AbstractChannel.AbstractUnsafe
Channel.Unsafe
Modifier and Type | Field and Description |
---|---|
protected boolean |
active |
protected int |
flags |
protected LinuxSocket |
socket |
Modifier | Constructor and Description |
---|---|
protected |
AbstractEpollStreamChannel(Channel parent,
int fd) |
protected |
AbstractEpollStreamChannel(Channel parent,
LinuxSocket fd,
SocketAddress remote) |
protected |
AbstractEpollStreamChannel(int fd) |
protected |
AbstractEpollStreamChannel(LinuxSocket fd,
boolean active) |
Modifier and Type | Method and Description |
---|---|
protected static void |
checkResolvable(InetSocketAddress addr) |
abstract EpollChannelConfig |
config()
Returns the configuration of this channel.
|
protected void |
doBeginRead()
Schedule a read operation.
|
protected void |
doBind(SocketAddress local)
Bind the
Channel to the SocketAddress |
protected void |
doClose()
Close the
Channel |
protected boolean |
doConnect(SocketAddress remoteAddress,
SocketAddress localAddress)
Connect to the remote peer
|
protected void |
doDeregister()
|
protected void |
doDisconnect()
Disconnect this
Channel from its remote peer |
protected int |
doReadBytes(ByteBuf byteBuf)
Read bytes into the given
ByteBuf and return the amount. |
protected void |
doRegister()
|
protected void |
doShutdownOutput()
Called when conditions justify shutting down the output portion of the channel.
|
protected void |
doWrite(ChannelOutboundBuffer in)
Flush the content of the given buffer to the remote peer.
|
protected int |
doWriteBytes(ChannelOutboundBuffer in,
ByteBuf buf) |
protected int |
doWriteSingle(ChannelOutboundBuffer in)
Attempt to write a single object.
|
FileDescriptor |
fd()
Returns the
FileDescriptor that is used by this Channel . |
protected Object |
filterOutboundMessage(Object msg)
Invoked when a new message is added to a
ChannelOutboundBuffer of this AbstractChannel , so that
the Channel implementation converts the message to another. |
boolean |
isActive()
Return
true if the Channel is active and so connected. |
protected boolean |
isCompatible(EventLoop loop)
Return
true if the given EventLoop is compatible with this instance. |
boolean |
isInputShutdown()
Returns
true if and only if the remote peer shut down its output so that no more
data is received from this channel. |
boolean |
isOpen()
Returns
true if the Channel is open and may get active later |
boolean |
isOutputShutdown() |
boolean |
isShutdown()
Determine if both the input and output of this channel have been shutdown.
|
protected SocketAddress |
localAddress0()
Returns the
SocketAddress which is bound locally. |
ChannelMetadata |
metadata()
|
protected ByteBuf |
newDirectBuffer(ByteBuf buf)
Returns an off-heap copy of the specified
ByteBuf , and releases the original one. |
protected ByteBuf |
newDirectBuffer(Object holder,
ByteBuf buf)
Returns an off-heap copy of the specified
ByteBuf , and releases the specified holder. |
protected io.netty.channel.epoll.AbstractEpollChannel.AbstractEpollUnsafe |
newUnsafe()
Create a new
AbstractChannel.AbstractUnsafe instance which will be used for the life-time of the Channel |
protected SocketAddress |
remoteAddress0()
Return the
SocketAddress which the Channel is connected to. |
protected void |
setFlag(int flag) |
ChannelFuture |
shutdown()
Will shutdown the input and output sides of this channel.
|
ChannelFuture |
shutdown(ChannelPromise promise)
Will shutdown the input and output sides of this channel.
|
ChannelFuture |
shutdownInput() |
ChannelFuture |
shutdownInput(ChannelPromise promise)
Will shutdown the input and notify
ChannelPromise . |
ChannelFuture |
shutdownOutput() |
ChannelFuture |
shutdownOutput(ChannelPromise promise)
Will shutdown the output and notify
ChannelPromise . |
ChannelFuture |
spliceTo(AbstractEpollStreamChannel ch,
int len)
Splice from this
AbstractEpollStreamChannel to another AbstractEpollStreamChannel . |
ChannelFuture |
spliceTo(AbstractEpollStreamChannel ch,
int len,
ChannelPromise promise)
Splice from this
AbstractEpollStreamChannel to another AbstractEpollStreamChannel . |
ChannelFuture |
spliceTo(FileDescriptor ch,
int offset,
int len)
Splice from this
AbstractEpollStreamChannel to another FileDescriptor . |
ChannelFuture |
spliceTo(FileDescriptor ch,
int offset,
int len,
ChannelPromise promise)
Splice from this
AbstractEpollStreamChannel to another FileDescriptor . |
alloc, bind, bind, bytesBeforeUnwritable, bytesBeforeWritable, close, close, closeFuture, compareTo, connect, connect, connect, connect, deregister, deregister, disconnect, disconnect, equals, eventLoop, flush, hashCode, id, invalidateLocalAddress, invalidateRemoteAddress, isRegistered, isWritable, localAddress, maxMessagesPerWrite, newChannelPipeline, newFailedFuture, newId, newProgressivePromise, newPromise, newSucceededFuture, parent, pipeline, read, remoteAddress, toString, unsafe, validateFileRegion, voidPromise, write, write, writeAndFlush, writeAndFlush
attr, hasAttr
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
alloc, bytesBeforeUnwritable, bytesBeforeWritable, closeFuture, config, eventLoop, flush, id, isActive, isOpen, isRegistered, isWritable, localAddress, parent, pipeline, read, remoteAddress, unsafe
attr, hasAttr
bind, bind, close, close, connect, connect, connect, connect, deregister, deregister, disconnect, disconnect, newFailedFuture, newProgressivePromise, newPromise, newSucceededFuture, voidPromise, write, write, writeAndFlush, writeAndFlush
compareTo
protected final LinuxSocket socket
protected int flags
protected volatile boolean active
protected AbstractEpollStreamChannel(Channel parent, int fd)
protected AbstractEpollStreamChannel(int fd)
protected AbstractEpollStreamChannel(Channel parent, LinuxSocket fd, SocketAddress remote)
protected AbstractEpollStreamChannel(LinuxSocket fd, boolean active)
protected io.netty.channel.epoll.AbstractEpollChannel.AbstractEpollUnsafe newUnsafe()
AbstractChannel
AbstractChannel.AbstractUnsafe
instance which will be used for the life-time of the Channel
public ChannelMetadata metadata()
Channel
public final ChannelFuture spliceTo(AbstractEpollStreamChannel ch, int len)
AbstractEpollStreamChannel
to another AbstractEpollStreamChannel
.
The len
is the number of bytes to splice. If using Integer.MAX_VALUE
it will
splice until the ChannelFuture
was canceled or it was failed.
Please note:
EventLoop
, otherwise an
IllegalArgumentException
is thrown. EpollChannelConfig.getEpollMode()
must be EpollMode.LEVEL_TRIGGERED
for this and the
target AbstractEpollStreamChannel
public final ChannelFuture spliceTo(AbstractEpollStreamChannel ch, int len, ChannelPromise promise)
AbstractEpollStreamChannel
to another AbstractEpollStreamChannel
.
The len
is the number of bytes to splice. If using Integer.MAX_VALUE
it will
splice until the ChannelFuture
was canceled or it was failed.
Please note:
EventLoop
, otherwise an
IllegalArgumentException
is thrown. EpollChannelConfig.getEpollMode()
must be EpollMode.LEVEL_TRIGGERED
for this and the
target AbstractEpollStreamChannel
public final ChannelFuture spliceTo(FileDescriptor ch, int offset, int len)
AbstractEpollStreamChannel
to another FileDescriptor
.
The offset
is the offset for the FileDescriptor
and len
is the
number of bytes to splice. If using Integer.MAX_VALUE
it will splice until the
ChannelFuture
was canceled or it was failed.
Please note:
EpollChannelConfig.getEpollMode()
must be EpollMode.LEVEL_TRIGGERED
for this
AbstractEpollStreamChannel
FileDescriptor
will not be closed after the ChannelFuture
is notifiedIllegalStateException
will be thrown.public final ChannelFuture spliceTo(FileDescriptor ch, int offset, int len, ChannelPromise promise)
AbstractEpollStreamChannel
to another FileDescriptor
.
The offset
is the offset for the FileDescriptor
and len
is the
number of bytes to splice. If using Integer.MAX_VALUE
it will splice until the
ChannelFuture
was canceled or it was failed.
Please note:
EpollChannelConfig.getEpollMode()
must be EpollMode.LEVEL_TRIGGERED
for this
AbstractEpollStreamChannel
FileDescriptor
will not be closed after the ChannelPromise
is notifiedIllegalStateException
will be thrown.protected void doWrite(ChannelOutboundBuffer in) throws Exception
AbstractChannel
doWrite
in class AbstractChannel
Exception
protected int doWriteSingle(ChannelOutboundBuffer in) throws Exception
in
- the collection which contains objects to write.ChannelConfig.getWriteSpinCount()
. The typical use cases are as follows:
ByteBuf
(or other empty content)
is encounteredChannelUtils.WRITE_STATUS_SNDBUF_FULL
- if an attempt to write data was made to the OS, but
no data was acceptedException
- If an I/O error occurs.protected Object filterOutboundMessage(Object msg)
AbstractChannel
ChannelOutboundBuffer
of this AbstractChannel
, so that
the Channel
implementation converts the message to another. (e.g. heap buffer -> direct buffer)filterOutboundMessage
in class AbstractChannel
protected final void doShutdownOutput() throws Exception
AbstractChannel
doShutdownOutput
in class AbstractChannel
Exception
public boolean isOutputShutdown()
isOutputShutdown
in interface DuplexChannel
Socket.isOutputShutdown()
public boolean isInputShutdown()
DuplexChannel
true
if and only if the remote peer shut down its output so that no more
data is received from this channel. Note that the semantic of this method is different from
that of Socket.shutdownInput()
and Socket.isInputShutdown()
.isInputShutdown
in interface DuplexChannel
public boolean isShutdown()
DuplexChannel
isShutdown
in interface DuplexChannel
public ChannelFuture shutdownOutput()
shutdownOutput
in interface DuplexChannel
Socket.shutdownOutput()
public ChannelFuture shutdownOutput(ChannelPromise promise)
DuplexChannel
ChannelPromise
.shutdownOutput
in interface DuplexChannel
Socket.shutdownOutput()
public ChannelFuture shutdownInput()
shutdownInput
in interface DuplexChannel
Socket.shutdownInput()
public ChannelFuture shutdownInput(ChannelPromise promise)
DuplexChannel
ChannelPromise
.shutdownInput
in interface DuplexChannel
Socket.shutdownInput()
public ChannelFuture shutdown()
DuplexChannel
shutdown
in interface DuplexChannel
public ChannelFuture shutdown(ChannelPromise promise)
DuplexChannel
shutdown
in interface DuplexChannel
promise
- will be completed when both shutdown operations complete.protected void doClose() throws Exception
AbstractChannel
Channel
Exception
protected void setFlag(int flag) throws IOException
IOException
public final FileDescriptor fd()
UnixChannel
FileDescriptor
that is used by this Channel
.fd
in interface UnixChannel
public abstract EpollChannelConfig config()
Channel
public boolean isActive()
Channel
true
if the Channel
is active and so connected.protected void doDisconnect() throws Exception
AbstractChannel
Channel
from its remote peerdoDisconnect
in class AbstractChannel
Exception
protected boolean isCompatible(EventLoop loop)
AbstractChannel
true
if the given EventLoop
is compatible with this instance.isCompatible
in class AbstractChannel
public boolean isOpen()
Channel
true
if the Channel
is open and may get active laterprotected void doDeregister() throws Exception
AbstractChannel
doDeregister
in class AbstractChannel
Exception
protected final void doBeginRead() throws Exception
AbstractChannel
doBeginRead
in class AbstractChannel
Exception
protected void doRegister() throws Exception
AbstractChannel
Channel
is registered with its EventLoop
as part of the register process.
Sub-classes may override this methoddoRegister
in class AbstractChannel
Exception
protected final ByteBuf newDirectBuffer(ByteBuf buf)
ByteBuf
, and releases the original one.protected static void checkResolvable(InetSocketAddress addr)
protected final int doReadBytes(ByteBuf byteBuf) throws Exception
ByteBuf
and return the amount.Exception
protected final int doWriteBytes(ChannelOutboundBuffer in, ByteBuf buf) throws Exception
Exception
protected void doBind(SocketAddress local) throws Exception
AbstractChannel
Channel
to the SocketAddress
doBind
in class AbstractChannel
Exception
protected boolean doConnect(SocketAddress remoteAddress, SocketAddress localAddress) throws Exception
Exception
protected SocketAddress localAddress0()
AbstractChannel
SocketAddress
which is bound locally.localAddress0
in class AbstractChannel
protected SocketAddress remoteAddress0()
AbstractChannel
SocketAddress
which the Channel
is connected to.remoteAddress0
in class AbstractChannel
Copyright © 2008–2024 The Netty Project. All rights reserved.