public final class EpollDatagramChannel extends AbstractChannel implements DatagramChannel
DatagramChannel
implementation that uses linux EPOLL Edge-Triggered Mode for
maximal performance.AbstractChannel.AbstractUnsafe
Channel.Unsafe
Modifier and Type | Field and Description |
---|---|
protected boolean |
active |
protected int |
flags |
protected LinuxSocket |
socket |
Constructor and Description |
---|
EpollDatagramChannel()
Create a new instance which selects the
InternetProtocolFamily to use depending
on the Operation Systems default which will be chosen. |
EpollDatagramChannel(int fd)
Create a new instance which selects the
InternetProtocolFamily to use depending
on the Operation Systems default which will be chosen. |
EpollDatagramChannel(InternetProtocolFamily family)
Create a new instance using the given
InternetProtocolFamily . |
Modifier and Type | Method and Description |
---|---|
ChannelFuture |
block(InetAddress multicastAddress,
InetAddress sourceToBlock)
Block the given sourceToBlock address for the given multicastAddress and notifies the
ChannelFuture once
the operation completes. |
ChannelFuture |
block(InetAddress multicastAddress,
InetAddress sourceToBlock,
ChannelPromise promise)
Block the given sourceToBlock address for the given multicastAddress and notifies the
ChannelFuture once
the operation completes. |
ChannelFuture |
block(InetAddress multicastAddress,
NetworkInterface networkInterface,
InetAddress sourceToBlock)
Block the given sourceToBlock address for the given multicastAddress on the given networkInterface and notifies
the
ChannelFuture once the operation completes. |
ChannelFuture |
block(InetAddress multicastAddress,
NetworkInterface networkInterface,
InetAddress sourceToBlock,
ChannelPromise promise)
Block the given sourceToBlock address for the given multicastAddress on the given networkInterface and notifies
the
ChannelFuture once the operation completes. |
protected static void |
checkResolvable(InetSocketAddress addr) |
EpollDatagramChannelConfig |
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 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 |
doWrite(ChannelOutboundBuffer in)
Flush the content of the given buffer to the remote peer.
|
protected int |
doWriteBytes(ChannelOutboundBuffer in,
ByteBuf buf) |
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 |
isConnected()
Return
true if the DatagramChannel is connected to the remote peer. |
boolean |
isOpen()
Returns
true if the Channel is open and may get active later |
static boolean |
isSegmentedDatagramPacketSupported()
Returns
true if SegmentedDatagramPacket is supported natively. |
ChannelFuture |
joinGroup(InetAddress multicastAddress)
Joins a multicast group and notifies the
ChannelFuture once the operation completes. |
ChannelFuture |
joinGroup(InetAddress multicastAddress,
ChannelPromise promise)
Joins a multicast group and notifies the
ChannelFuture once the operation completes. |
ChannelFuture |
joinGroup(InetAddress multicastAddress,
NetworkInterface networkInterface,
InetAddress source)
Joins the specified multicast group at the specified interface and notifies the
ChannelFuture
once the operation completes. |
ChannelFuture |
joinGroup(InetAddress multicastAddress,
NetworkInterface networkInterface,
InetAddress source,
ChannelPromise promise)
Joins the specified multicast group at the specified interface and notifies the
ChannelFuture
once the operation completes. |
ChannelFuture |
joinGroup(InetSocketAddress multicastAddress,
NetworkInterface networkInterface)
Joins the specified multicast group at the specified interface and notifies the
ChannelFuture
once the operation completes. |
ChannelFuture |
joinGroup(InetSocketAddress multicastAddress,
NetworkInterface networkInterface,
ChannelPromise promise)
Joins the specified multicast group at the specified interface and notifies the
ChannelFuture
once the operation completes. |
ChannelFuture |
leaveGroup(InetAddress multicastAddress)
Leaves a multicast group and notifies the
ChannelFuture once the operation completes. |
ChannelFuture |
leaveGroup(InetAddress multicastAddress,
ChannelPromise promise)
Leaves a multicast group and notifies the
ChannelFuture once the operation completes. |
ChannelFuture |
leaveGroup(InetAddress multicastAddress,
NetworkInterface networkInterface,
InetAddress source)
Leave the specified multicast group at the specified interface using the specified source and notifies
the
ChannelFuture once the operation completes. |
ChannelFuture |
leaveGroup(InetAddress multicastAddress,
NetworkInterface networkInterface,
InetAddress source,
ChannelPromise promise)
Leave the specified multicast group at the specified interface using the specified source and notifies
the
ChannelFuture once the operation completes. |
ChannelFuture |
leaveGroup(InetSocketAddress multicastAddress,
NetworkInterface networkInterface)
Leaves a multicast group on a specified local interface and notifies the
ChannelFuture once the
operation completes. |
ChannelFuture |
leaveGroup(InetSocketAddress multicastAddress,
NetworkInterface networkInterface,
ChannelPromise promise)
Leaves a multicast group on a specified local interface and notifies the
ChannelFuture once the
operation completes. |
InetSocketAddress |
localAddress()
Returns the local address where this channel is bound to.
|
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 |
InetSocketAddress |
remoteAddress()
Returns the remote address where this channel is connected to.
|
protected SocketAddress |
remoteAddress0()
Return the
SocketAddress which the Channel is connected to. |
protected void |
setFlag(int flag) |
alloc, bind, bind, bytesBeforeUnwritable, bytesBeforeWritable, close, close, closeFuture, compareTo, connect, connect, connect, connect, deregister, deregister, disconnect, disconnect, doShutdownOutput, 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, writeAndFlush
attr, hasAttr
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
alloc, bytesBeforeUnwritable, bytesBeforeWritable, closeFuture, eventLoop, flush, id, isOpen, isRegistered, isWritable, parent, pipeline, read, 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
public EpollDatagramChannel()
InternetProtocolFamily
to use depending
on the Operation Systems default which will be chosen.public EpollDatagramChannel(InternetProtocolFamily family)
InternetProtocolFamily
. If null
is used it will depend
on the Operation Systems default which will be chosen.public EpollDatagramChannel(int fd)
InternetProtocolFamily
to use depending
on the Operation Systems default which will be chosen.public static boolean isSegmentedDatagramPacketSupported()
true
if SegmentedDatagramPacket
is supported natively.true
if supported, false
otherwise.public InetSocketAddress remoteAddress()
Channel
SocketAddress
is supposed to be down-cast into more
concrete type such as InetSocketAddress
to retrieve the detailed
information.remoteAddress
in interface Channel
remoteAddress
in interface DatagramChannel
remoteAddress
in class AbstractChannel
null
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 InetSocketAddress localAddress()
Channel
SocketAddress
is supposed to be down-cast into more concrete
type such as InetSocketAddress
to retrieve the detailed
information.localAddress
in interface Channel
localAddress
in interface DatagramChannel
localAddress
in class AbstractChannel
null
if this channel is not bound.public ChannelMetadata metadata()
Channel
public boolean isActive()
Channel
true
if the Channel
is active and so connected.public boolean isConnected()
DatagramChannel
true
if the DatagramChannel
is connected to the remote peer.isConnected
in interface DatagramChannel
public ChannelFuture joinGroup(InetAddress multicastAddress)
DatagramChannel
ChannelFuture
once the operation completes.joinGroup
in interface DatagramChannel
public ChannelFuture joinGroup(InetAddress multicastAddress, ChannelPromise promise)
DatagramChannel
ChannelFuture
once the operation completes.
The given ChannelFuture
will be notified and also returned.joinGroup
in interface DatagramChannel
public ChannelFuture joinGroup(InetSocketAddress multicastAddress, NetworkInterface networkInterface)
DatagramChannel
ChannelFuture
once the operation completes.joinGroup
in interface DatagramChannel
public ChannelFuture joinGroup(InetSocketAddress multicastAddress, NetworkInterface networkInterface, ChannelPromise promise)
DatagramChannel
ChannelFuture
once the operation completes.
The given ChannelFuture
will be notified and also returned.joinGroup
in interface DatagramChannel
public ChannelFuture joinGroup(InetAddress multicastAddress, NetworkInterface networkInterface, InetAddress source)
DatagramChannel
ChannelFuture
once the operation completes.joinGroup
in interface DatagramChannel
public ChannelFuture joinGroup(InetAddress multicastAddress, NetworkInterface networkInterface, InetAddress source, ChannelPromise promise)
DatagramChannel
ChannelFuture
once the operation completes.
The given ChannelFuture
will be notified and also returned.joinGroup
in interface DatagramChannel
public ChannelFuture leaveGroup(InetAddress multicastAddress)
DatagramChannel
ChannelFuture
once the operation completes.leaveGroup
in interface DatagramChannel
public ChannelFuture leaveGroup(InetAddress multicastAddress, ChannelPromise promise)
DatagramChannel
ChannelFuture
once the operation completes.
The given ChannelFuture
will be notified and also returned.leaveGroup
in interface DatagramChannel
public ChannelFuture leaveGroup(InetSocketAddress multicastAddress, NetworkInterface networkInterface)
DatagramChannel
ChannelFuture
once the
operation completes.leaveGroup
in interface DatagramChannel
public ChannelFuture leaveGroup(InetSocketAddress multicastAddress, NetworkInterface networkInterface, ChannelPromise promise)
DatagramChannel
ChannelFuture
once the
operation completes.
The given ChannelFuture
will be notified and also returned.leaveGroup
in interface DatagramChannel
public ChannelFuture leaveGroup(InetAddress multicastAddress, NetworkInterface networkInterface, InetAddress source)
DatagramChannel
ChannelFuture
once the operation completes.leaveGroup
in interface DatagramChannel
public ChannelFuture leaveGroup(InetAddress multicastAddress, NetworkInterface networkInterface, InetAddress source, ChannelPromise promise)
DatagramChannel
ChannelFuture
once the operation completes.
The given ChannelFuture
will be notified and also returned.leaveGroup
in interface DatagramChannel
public ChannelFuture block(InetAddress multicastAddress, NetworkInterface networkInterface, InetAddress sourceToBlock)
DatagramChannel
ChannelFuture
once the operation completes.
The given ChannelFuture
will be notified and also returned.block
in interface DatagramChannel
public ChannelFuture block(InetAddress multicastAddress, NetworkInterface networkInterface, InetAddress sourceToBlock, ChannelPromise promise)
DatagramChannel
ChannelFuture
once the operation completes.
The given ChannelFuture
will be notified and also returned.block
in interface DatagramChannel
public ChannelFuture block(InetAddress multicastAddress, InetAddress sourceToBlock)
DatagramChannel
ChannelFuture
once
the operation completes.
The given ChannelFuture
will be notified and also returned.block
in interface DatagramChannel
public ChannelFuture block(InetAddress multicastAddress, InetAddress sourceToBlock, ChannelPromise promise)
DatagramChannel
ChannelFuture
once
the operation completes.
The given ChannelFuture
will be notified and also returned.block
in interface DatagramChannel
protected io.netty.channel.epoll.AbstractEpollChannel.AbstractEpollUnsafe newUnsafe()
AbstractChannel
AbstractChannel.AbstractUnsafe
instance which will be used for the life-time of the Channel
protected void doBind(SocketAddress localAddress) throws Exception
AbstractChannel
Channel
to the SocketAddress
Exception
protected void doWrite(ChannelOutboundBuffer in) throws Exception
AbstractChannel
doWrite
in class AbstractChannel
Exception
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
public EpollDatagramChannelConfig config()
Channel
config
in interface Channel
config
in interface DatagramChannel
protected void doDisconnect() throws Exception
AbstractChannel
Channel
from its remote peerException
protected boolean doConnect(SocketAddress remoteAddress, SocketAddress localAddress) throws Exception
Exception
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
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 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.