public final class EpollDomainSocketChannel extends AbstractEpollStreamChannel implements DomainSocketChannel
AbstractEpollStreamChannel.SpliceInTaskAbstractChannel.AbstractUnsafeChannel.Unsafe| Modifier and Type | Field and Description |
|---|---|
protected boolean |
active |
protected int |
flags |
protected LinuxSocket |
socket |
| Constructor and Description |
|---|
EpollDomainSocketChannel() |
EpollDomainSocketChannel(Channel parent,
LinuxSocket fd) |
EpollDomainSocketChannel(int fd) |
EpollDomainSocketChannel(int fd,
boolean active) |
| Modifier and Type | Method and Description |
|---|---|
protected static void |
checkResolvable(InetSocketAddress addr) |
EpollDomainSocketChannelConfig |
config()
Returns the configuration of this channel.
|
protected void |
doBeginRead()
Schedule a read operation.
|
protected void |
doBind(SocketAddress localAddress)
Bind the
Channel to the SocketAddress |
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 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 |
isOpen()
Returns
true if the Channel is open and may get active later |
DomainSocketAddress |
localAddress()
Returns the local address where this channel is bound to.
|
protected DomainSocketAddress |
localAddress0()
Returns the
SocketAddress which is bound locally. |
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 |
PeerCredentials |
peerCredentials()
Returns the unix credentials (uid, gid, pid) of the peer
SO_PEERCRED
|
DomainSocketAddress |
remoteAddress()
Returns the remote address where this channel is connected to.
|
protected DomainSocketAddress |
remoteAddress0()
Return the
SocketAddress which the Channel is connected to. |
protected void |
setFlag(int flag) |
doClose, doShutdownOutput, doWrite, isInputShutdown, isOutputShutdown, isShutdown, metadata, shutdown, shutdown, shutdownInput, shutdownInput, shutdownOutput, shutdownOutput, spliceTo, spliceTo, spliceTo, spliceToalloc, 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, maxMessagesPerWrite, newChannelPipeline, newFailedFuture, newId, newProgressivePromise, newPromise, newSucceededFuture, parent, pipeline, read, toString, unsafe, validateFileRegion, voidPromise, write, write, writeAndFlush, writeAndFlushattr, hasAttrclone, finalize, getClass, notify, notifyAll, wait, wait, waitfdisInputShutdown, isOutputShutdown, isShutdown, shutdown, shutdown, shutdownInput, shutdownInput, shutdownOutput, shutdownOutputalloc, bytesBeforeUnwritable, bytesBeforeWritable, closeFuture, eventLoop, flush, id, isActive, isOpen, isRegistered, isWritable, metadata, parent, pipeline, read, unsafeattr, hasAttrbind, bind, close, close, connect, connect, connect, connect, deregister, deregister, disconnect, disconnect, newFailedFuture, newProgressivePromise, newPromise, newSucceededFuture, voidPromise, write, write, writeAndFlush, writeAndFlushcompareToprotected final LinuxSocket socket
protected int flags
protected volatile boolean active
public EpollDomainSocketChannel()
public EpollDomainSocketChannel(int fd)
public EpollDomainSocketChannel(Channel parent, LinuxSocket fd)
public EpollDomainSocketChannel(int fd,
boolean active)
protected io.netty.channel.epoll.AbstractEpollChannel.AbstractEpollUnsafe newUnsafe()
AbstractChannelAbstractChannel.AbstractUnsafe instance which will be used for the life-time of the ChannelnewUnsafe in class AbstractEpollStreamChannelprotected DomainSocketAddress localAddress0()
AbstractChannelSocketAddress which is bound locally.protected DomainSocketAddress remoteAddress0()
AbstractChannelSocketAddress which the Channel is connected to.protected void doBind(SocketAddress localAddress) throws Exception
AbstractChannelChannel to the SocketAddressExceptionpublic EpollDomainSocketChannelConfig config()
Channelconfig in interface Channelconfig in interface DomainSocketChannelprotected boolean doConnect(SocketAddress remoteAddress, SocketAddress localAddress) throws Exception
Exceptionpublic DomainSocketAddress remoteAddress()
ChannelSocketAddress is supposed to be down-cast into more
concrete type such as InetSocketAddress to retrieve the detailed
information.remoteAddress in interface ChannelremoteAddress in interface DomainSocketChannelremoteAddress in class AbstractChannelnull if this channel is not connected.
If this channel is not connected but it can receive messages
from arbitrary remote addresses (e.g. DatagramChannel,
use DefaultAddressedEnvelope.recipient() to determine
the origination of the received message as this method will
return null.public DomainSocketAddress localAddress()
ChannelSocketAddress is supposed to be down-cast into more concrete
type such as InetSocketAddress to retrieve the detailed
information.localAddress in interface ChannellocalAddress in interface DomainSocketChannellocalAddress in class AbstractChannelnull if this channel is not bound.protected int doWriteSingle(ChannelOutboundBuffer in) throws Exception
AbstractEpollStreamChanneldoWriteSingle in class AbstractEpollStreamChannelin - 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)
AbstractChannelChannelOutboundBuffer of this AbstractChannel, so that
the Channel implementation converts the message to another. (e.g. heap buffer -> direct buffer)filterOutboundMessage in class AbstractEpollStreamChannelpublic PeerCredentials peerCredentials() throws IOException
IOExceptionprotected void setFlag(int flag)
throws IOException
IOExceptionpublic final FileDescriptor fd()
UnixChannelFileDescriptor that is used by this Channel.fd in interface UnixChannelpublic boolean isActive()
Channeltrue if the Channel is active and so connected.protected void doDisconnect()
throws Exception
AbstractChannelChannel from its remote peerdoDisconnect in class AbstractChannelExceptionprotected boolean isCompatible(EventLoop loop)
AbstractChanneltrue if the given EventLoop is compatible with this instance.isCompatible in class AbstractChannelpublic boolean isOpen()
Channeltrue if the Channel is open and may get active laterprotected void doDeregister()
throws Exception
AbstractChanneldoDeregister in class AbstractChannelExceptionprotected final void doBeginRead()
throws Exception
AbstractChanneldoBeginRead in class AbstractChannelExceptionprotected void doRegister()
throws Exception
AbstractChannelChannel is registered with its EventLoop as part of the register process.
Sub-classes may override this methoddoRegister in class AbstractChannelExceptionprotected 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.Exceptionprotected final int doWriteBytes(ChannelOutboundBuffer in, ByteBuf buf) throws Exception
ExceptionCopyright © 2008–2025 The Netty Project. All rights reserved.