Fit to 120 column (Done)
This commit is contained in:
parent
9479636bd6
commit
3fb5b9e105
@ -231,12 +231,13 @@ public class ClientBootstrap extends Bootstrap {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Attempts to bind a channel with the specified {@code localAddress}. later the channel can be connected
|
* Attempts to bind a channel with the specified {@code localAddress}. later the channel can
|
||||||
* to a remoteAddress by calling {@link Channel#connect(SocketAddress)}.This method is useful where bind and connect
|
* be connected to a remoteAddress by calling {@link Channel#connect(SocketAddress)}.This method
|
||||||
* need to be done in separate steps.
|
* is useful where bind and connect need to be done in separate steps.
|
||||||
*
|
*
|
||||||
* This can also be useful if you want to set an attachment to the {@link Channel} via
|
* This can also be useful if you want to set an attachment to the {@link Channel} via
|
||||||
* {@link Channel#setAttachment(Object)} so you can use it after the {@link #bind(SocketAddress)} was done.
|
* {@link Channel#setAttachment(Object)} so you can use it after the {@link #bind(SocketAddress)}
|
||||||
|
* was done.
|
||||||
* <br>
|
* <br>
|
||||||
* For example:
|
* For example:
|
||||||
*
|
*
|
||||||
|
@ -1723,13 +1723,15 @@ public interface ChannelBuffer extends Comparable<ChannelBuffer> {
|
|||||||
String charsetName, ChannelBufferIndexFinder terminatorFinder);
|
String charsetName, ChannelBufferIndexFinder terminatorFinder);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @deprecated Use {@link #bytesBefore(int, int, ChannelBufferIndexFinder)} and {@link #toString(int, int, Charset)} instead.
|
* @deprecated Use {@link #bytesBefore(int, int, ChannelBufferIndexFinder)} and
|
||||||
|
* {@link #toString(int, int, Charset)} instead.
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
String toString(int index, int length, String charsetName);
|
String toString(int index, int length, String charsetName);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @deprecated Use {@link #bytesBefore(int, int, ChannelBufferIndexFinder)} and {@link #toString(int, int, Charset)} instead.
|
* @deprecated Use {@link #bytesBefore(int, int, ChannelBufferIndexFinder)} and
|
||||||
|
* {@link #toString(int, int, Charset)} instead.
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
String toString(
|
String toString(
|
||||||
|
@ -227,7 +227,8 @@ public final class ChannelBuffers {
|
|||||||
* More accurate estimation yields less unexpected reallocation overhead.
|
* More accurate estimation yields less unexpected reallocation overhead.
|
||||||
* The new buffer's {@code readerIndex} and {@code writerIndex} are {@code 0}.
|
* The new buffer's {@code readerIndex} and {@code writerIndex} are {@code 0}.
|
||||||
*/
|
*/
|
||||||
public static ChannelBuffer dynamicBuffer(ByteOrder endianness, int estimatedLength, ChannelBufferFactory factory) {
|
public static ChannelBuffer dynamicBuffer(
|
||||||
|
ByteOrder endianness, int estimatedLength, ChannelBufferFactory factory) {
|
||||||
return new DynamicChannelBuffer(endianness, estimatedLength, factory);
|
return new DynamicChannelBuffer(endianness, estimatedLength, factory);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -308,7 +309,8 @@ public final class ChannelBuffers {
|
|||||||
return EMPTY_BUFFER;
|
return EMPTY_BUFFER;
|
||||||
}
|
}
|
||||||
if (buffer.hasArray()) {
|
if (buffer.hasArray()) {
|
||||||
return wrappedBuffer(buffer.order(), buffer.array(), buffer.arrayOffset() + buffer.position(), buffer.remaining());
|
return wrappedBuffer(
|
||||||
|
buffer.order(), buffer.array(), buffer.arrayOffset() + buffer.position(), buffer.remaining());
|
||||||
} else {
|
} else {
|
||||||
return new ByteBufferBackedChannelBuffer(buffer);
|
return new ByteBufferBackedChannelBuffer(buffer);
|
||||||
}
|
}
|
||||||
@ -1050,7 +1052,8 @@ public final class ChannelBuffers {
|
|||||||
* The default implementation of {@link ChannelBuffer#indexOf(int, int, ChannelBufferIndexFinder)}.
|
* The default implementation of {@link ChannelBuffer#indexOf(int, int, ChannelBufferIndexFinder)}.
|
||||||
* This method is useful when implementing a new buffer type.
|
* This method is useful when implementing a new buffer type.
|
||||||
*/
|
*/
|
||||||
public static int indexOf(ChannelBuffer buffer, int fromIndex, int toIndex, ChannelBufferIndexFinder indexFinder) {
|
public static int indexOf(
|
||||||
|
ChannelBuffer buffer, int fromIndex, int toIndex, ChannelBufferIndexFinder indexFinder) {
|
||||||
if (fromIndex <= toIndex) {
|
if (fromIndex <= toIndex) {
|
||||||
return firstIndexOf(buffer, fromIndex, toIndex, indexFinder);
|
return firstIndexOf(buffer, fromIndex, toIndex, indexFinder);
|
||||||
} else {
|
} else {
|
||||||
@ -1118,7 +1121,8 @@ public final class ChannelBuffers {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static int firstIndexOf(ChannelBuffer buffer, int fromIndex, int toIndex, ChannelBufferIndexFinder indexFinder) {
|
private static int firstIndexOf(
|
||||||
|
ChannelBuffer buffer, int fromIndex, int toIndex, ChannelBufferIndexFinder indexFinder) {
|
||||||
fromIndex = Math.max(fromIndex, 0);
|
fromIndex = Math.max(fromIndex, 0);
|
||||||
if (fromIndex >= toIndex || buffer.capacity() == 0) {
|
if (fromIndex >= toIndex || buffer.capacity() == 0) {
|
||||||
return -1;
|
return -1;
|
||||||
@ -1133,7 +1137,8 @@ public final class ChannelBuffers {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static int lastIndexOf(ChannelBuffer buffer, int fromIndex, int toIndex, ChannelBufferIndexFinder indexFinder) {
|
private static int lastIndexOf(
|
||||||
|
ChannelBuffer buffer, int fromIndex, int toIndex, ChannelBufferIndexFinder indexFinder) {
|
||||||
fromIndex = Math.min(fromIndex, buffer.capacity());
|
fromIndex = Math.min(fromIndex, buffer.capacity());
|
||||||
if (fromIndex < 0 || buffer.capacity() == 0) {
|
if (fromIndex < 0 || buffer.capacity() == 0) {
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -56,11 +56,11 @@ public class DirectChannelBufferFactory extends AbstractChannelBufferFactory {
|
|||||||
|
|
||||||
private final Object bigEndianLock = new Object();
|
private final Object bigEndianLock = new Object();
|
||||||
private final Object littleEndianLock = new Object();
|
private final Object littleEndianLock = new Object();
|
||||||
private final int preallocatedBufferCapacity;
|
private final int preallocatedBufCapacity;
|
||||||
private ChannelBuffer preallocatedBigEndianBuffer;
|
private ChannelBuffer preallocatedBEBuf;
|
||||||
private int preallocatedBigEndianBufferPosition;
|
private int preallocatedBEBufPos;
|
||||||
private ChannelBuffer preallocatedLittleEndianBuffer;
|
private ChannelBuffer preallocatedLEBuf;
|
||||||
private int preallocatedLittleEndianBufferPosition;
|
private int preallocatedLEBufPos;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new factory whose default {@link ByteOrder} is
|
* Creates a new factory whose default {@link ByteOrder} is
|
||||||
@ -96,10 +96,10 @@ public class DirectChannelBufferFactory extends AbstractChannelBufferFactory {
|
|||||||
super(defaultOrder);
|
super(defaultOrder);
|
||||||
if (preallocatedBufferCapacity <= 0) {
|
if (preallocatedBufferCapacity <= 0) {
|
||||||
throw new IllegalArgumentException(
|
throw new IllegalArgumentException(
|
||||||
"preallocatedBufferCapacity must be greater than 0: " + preallocatedBufferCapacity);
|
"preallocatedBufCapacity must be greater than 0: " + preallocatedBufferCapacity);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.preallocatedBufferCapacity = preallocatedBufferCapacity;
|
this.preallocatedBufCapacity = preallocatedBufferCapacity;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ChannelBuffer getBuffer(ByteOrder order, int capacity) {
|
public ChannelBuffer getBuffer(ByteOrder order, int capacity) {
|
||||||
@ -112,7 +112,7 @@ public class DirectChannelBufferFactory extends AbstractChannelBufferFactory {
|
|||||||
if (capacity == 0) {
|
if (capacity == 0) {
|
||||||
return ChannelBuffers.EMPTY_BUFFER;
|
return ChannelBuffers.EMPTY_BUFFER;
|
||||||
}
|
}
|
||||||
if (capacity >= preallocatedBufferCapacity) {
|
if (capacity >= preallocatedBufCapacity) {
|
||||||
return ChannelBuffers.directBuffer(order, capacity);
|
return ChannelBuffers.directBuffer(order, capacity);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -160,17 +160,17 @@ public class DirectChannelBufferFactory extends AbstractChannelBufferFactory {
|
|||||||
private ChannelBuffer allocateBigEndianBuffer(int capacity) {
|
private ChannelBuffer allocateBigEndianBuffer(int capacity) {
|
||||||
ChannelBuffer slice;
|
ChannelBuffer slice;
|
||||||
synchronized (bigEndianLock) {
|
synchronized (bigEndianLock) {
|
||||||
if (preallocatedBigEndianBuffer == null) {
|
if (preallocatedBEBuf == null) {
|
||||||
preallocatedBigEndianBuffer = ChannelBuffers.directBuffer(ByteOrder.BIG_ENDIAN, preallocatedBufferCapacity);
|
preallocatedBEBuf = ChannelBuffers.directBuffer(ByteOrder.BIG_ENDIAN, preallocatedBufCapacity);
|
||||||
slice = preallocatedBigEndianBuffer.slice(0, capacity);
|
slice = preallocatedBEBuf.slice(0, capacity);
|
||||||
preallocatedBigEndianBufferPosition = capacity;
|
preallocatedBEBufPos = capacity;
|
||||||
} else if (preallocatedBigEndianBuffer.capacity() - preallocatedBigEndianBufferPosition >= capacity) {
|
} else if (preallocatedBEBuf.capacity() - preallocatedBEBufPos >= capacity) {
|
||||||
slice = preallocatedBigEndianBuffer.slice(preallocatedBigEndianBufferPosition, capacity);
|
slice = preallocatedBEBuf.slice(preallocatedBEBufPos, capacity);
|
||||||
preallocatedBigEndianBufferPosition += capacity;
|
preallocatedBEBufPos += capacity;
|
||||||
} else {
|
} else {
|
||||||
preallocatedBigEndianBuffer = ChannelBuffers.directBuffer(ByteOrder.BIG_ENDIAN, preallocatedBufferCapacity);
|
preallocatedBEBuf = ChannelBuffers.directBuffer(ByteOrder.BIG_ENDIAN, preallocatedBufCapacity);
|
||||||
slice = preallocatedBigEndianBuffer.slice(0, capacity);
|
slice = preallocatedBEBuf.slice(0, capacity);
|
||||||
preallocatedBigEndianBufferPosition = capacity;
|
preallocatedBEBufPos = capacity;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return slice;
|
return slice;
|
||||||
@ -179,17 +179,17 @@ public class DirectChannelBufferFactory extends AbstractChannelBufferFactory {
|
|||||||
private ChannelBuffer allocateLittleEndianBuffer(int capacity) {
|
private ChannelBuffer allocateLittleEndianBuffer(int capacity) {
|
||||||
ChannelBuffer slice;
|
ChannelBuffer slice;
|
||||||
synchronized (littleEndianLock) {
|
synchronized (littleEndianLock) {
|
||||||
if (preallocatedLittleEndianBuffer == null) {
|
if (preallocatedLEBuf == null) {
|
||||||
preallocatedLittleEndianBuffer = ChannelBuffers.directBuffer(ByteOrder.LITTLE_ENDIAN, preallocatedBufferCapacity);
|
preallocatedLEBuf = ChannelBuffers.directBuffer(ByteOrder.LITTLE_ENDIAN, preallocatedBufCapacity);
|
||||||
slice = preallocatedLittleEndianBuffer.slice(0, capacity);
|
slice = preallocatedLEBuf.slice(0, capacity);
|
||||||
preallocatedLittleEndianBufferPosition = capacity;
|
preallocatedLEBufPos = capacity;
|
||||||
} else if (preallocatedLittleEndianBuffer.capacity() - preallocatedLittleEndianBufferPosition >= capacity) {
|
} else if (preallocatedLEBuf.capacity() - preallocatedLEBufPos >= capacity) {
|
||||||
slice = preallocatedLittleEndianBuffer.slice(preallocatedLittleEndianBufferPosition, capacity);
|
slice = preallocatedLEBuf.slice(preallocatedLEBufPos, capacity);
|
||||||
preallocatedLittleEndianBufferPosition += capacity;
|
preallocatedLEBufPos += capacity;
|
||||||
} else {
|
} else {
|
||||||
preallocatedLittleEndianBuffer = ChannelBuffers.directBuffer(ByteOrder.LITTLE_ENDIAN, preallocatedBufferCapacity);
|
preallocatedLEBuf = ChannelBuffers.directBuffer(ByteOrder.LITTLE_ENDIAN, preallocatedBufCapacity);
|
||||||
slice = preallocatedLittleEndianBuffer.slice(0, capacity);
|
slice = preallocatedLEBuf.slice(0, capacity);
|
||||||
preallocatedLittleEndianBufferPosition = capacity;
|
preallocatedLEBufPos = capacity;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return slice;
|
return slice;
|
||||||
|
@ -29,46 +29,60 @@ import java.net.SocketAddress;
|
|||||||
* <th>Direction</th><th>State</th><th>Value</th><th>Meaning</th>
|
* <th>Direction</th><th>State</th><th>Value</th><th>Meaning</th>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Upstream</td><td>{@link #OPEN}</td><td>{@code true}</td><td>The channel is open.</td>
|
* <td>Upstream</td><td>{@link #OPEN}</td>
|
||||||
|
* <td>{@code true}</td><td>The channel is open.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Upstream</td><td>{@link #OPEN}</td><td>{@code false}</td><td>The channel is closed.</td>
|
* <td>Upstream</td><td>{@link #OPEN}</td>
|
||||||
|
* <td>{@code false}</td><td>The channel is closed.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Upstream</td><td>{@link #BOUND}</td><td>{@link SocketAddress}</td><td>The channel is bound to a local address.</td>
|
* <td>Upstream</td><td>{@link #BOUND}</td>
|
||||||
|
* <td>{@link SocketAddress}</td><td>The channel is bound to a local address.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Upstream</td><td>{@link #BOUND}</td><td>{@code null}</td><td>The channel is unbound to a local address.</td>
|
* <td>Upstream</td><td>{@link #BOUND}</td>
|
||||||
|
* <td>{@code null}</td><td>The channel is unbound to a local address.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Upstream</td><td>{@link #CONNECTED}</td><td>{@link SocketAddress}</td><td>The channel is connected to a remote address.</td>
|
* <td>Upstream</td><td>{@link #CONNECTED}</td>
|
||||||
|
* <td>{@link SocketAddress}</td><td>The channel is connected to a remote address.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Upstream</td><td>{@link #CONNECTED}</td><td>{@code null}</td><td>The channel is disconnected from a remote address.</td>
|
* <td>Upstream</td><td>{@link #CONNECTED}</td>
|
||||||
|
* <td>{@code null}</td><td>The channel is disconnected from a remote address.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Upstream</td><td>{@link #INTEREST_OPS}</td><td>an integer</td><td>The channel interestOps has been changed.</td>
|
* <td>Upstream</td><td>{@link #INTEREST_OPS}</td>
|
||||||
|
* <td>an integer</td><td>The channel interestOps has been changed.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Downstream</td><td>{@link #OPEN}</td><td>{@code true}</td><td>N/A</td>
|
* <td>Downstream</td><td>{@link #OPEN}</td>
|
||||||
|
* <td>{@code true}</td><td>N/A</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Downstream</td><td>{@link #OPEN}</td><td>{@code false}</td><td>Close the channel.</td>
|
* <td>Downstream</td><td>{@link #OPEN}</td>
|
||||||
|
* <td>{@code false}</td><td>Close the channel.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Downstream</td><td>{@link #BOUND}</td><td>{@link SocketAddress}</td><td>Bind the channel to the specified local address.</td>
|
* <td>Downstream</td><td>{@link #BOUND}</td>
|
||||||
|
* <td>{@link SocketAddress}</td><td>Bind the channel to the specified local address.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Downstream</td><td>{@link #BOUND}</td><td>{@code null}</td><td>Unbind the channel from the current local address.</td>
|
* <td>Downstream</td><td>{@link #BOUND}</td>
|
||||||
|
* <td>{@code null}</td><td>Unbind the channel from the current local address.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Downstream</td><td>{@link #CONNECTED}</td><td>{@link SocketAddress}</td><td>Connect the channel to the specified remote address.</td>
|
* <td>Downstream</td><td>{@link #CONNECTED}</td>
|
||||||
|
* <td>{@link SocketAddress}</td><td>Connect the channel to the specified remote address.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Downstream</td><td>{@link #CONNECTED}</td><td>{@code null}</td><td>Disconnect the channel from the current remote address.</td>
|
* <td>Downstream</td><td>{@link #CONNECTED}</td>
|
||||||
|
* <td>{@code null}</td><td>Disconnect the channel from the current remote address.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* <tr>
|
* <tr>
|
||||||
* <td>Downstream</td><td>{@link #INTEREST_OPS}</td><td>an integer</td><td>Change the interestOps of the channel.</td>
|
* <td>Downstream</td><td>{@link #INTEREST_OPS}</td>
|
||||||
|
* <td>an integer</td><td>Change the interestOps of the channel.</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* </table>
|
* </table>
|
||||||
* <p>
|
* <p>
|
||||||
|
@ -55,7 +55,9 @@ final class DefaultLocalChannel extends AbstractChannel implements LocalChannel
|
|||||||
volatile LocalAddress localAddress;
|
volatile LocalAddress localAddress;
|
||||||
volatile LocalAddress remoteAddress;
|
volatile LocalAddress remoteAddress;
|
||||||
|
|
||||||
DefaultLocalChannel(LocalServerChannel parent, ChannelFactory factory, ChannelPipeline pipeline, ChannelSink sink, DefaultLocalChannel pairedChannel) {
|
DefaultLocalChannel(
|
||||||
|
LocalServerChannel parent, ChannelFactory factory, ChannelPipeline pipeline,
|
||||||
|
ChannelSink sink, DefaultLocalChannel pairedChannel) {
|
||||||
super(parent, factory, pipeline, sink);
|
super(parent, factory, pipeline, sink);
|
||||||
this.pairedChannel = pairedChannel;
|
this.pairedChannel = pairedChannel;
|
||||||
config = new DefaultChannelConfig();
|
config = new DefaultChannelConfig();
|
||||||
|
@ -43,8 +43,8 @@ public class DefaultLocalServerChannelFactory implements LocalServerChannelFacto
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Release all the previous created channels. This takes care of calling {@link LocalChannelRegistry#unregister(LocalAddress)}
|
* Release all the previous created channels.
|
||||||
* for each if them.
|
* This takes care of calling {@link LocalChannelRegistry#unregister(LocalAddress)} for each of them.
|
||||||
*/
|
*/
|
||||||
public void releaseExternalResources() {
|
public void releaseExternalResources() {
|
||||||
group.close().awaitUninterruptibly();
|
group.close().awaitUninterruptibly();
|
||||||
|
@ -15,9 +15,9 @@
|
|||||||
*/
|
*/
|
||||||
package org.jboss.netty.channel.socket;
|
package org.jboss.netty.channel.socket;
|
||||||
|
|
||||||
import java.net.DatagramSocket;
|
|
||||||
import java.net.InetAddress;
|
import java.net.InetAddress;
|
||||||
import java.net.NetworkInterface;
|
import java.net.NetworkInterface;
|
||||||
|
import java.net.StandardSocketOptions;
|
||||||
|
|
||||||
import org.jboss.netty.channel.ChannelConfig;
|
import org.jboss.netty.channel.ChannelConfig;
|
||||||
import org.jboss.netty.channel.FixedReceiveBufferSizePredictor;
|
import org.jboss.netty.channel.FixedReceiveBufferSizePredictor;
|
||||||
@ -49,9 +49,11 @@ import org.jboss.netty.channel.ReceiveBufferSizePredictorFactory;
|
|||||||
* </tr><tr>
|
* </tr><tr>
|
||||||
* <td>{@code "receiveBufferSize"}</td><td>{@link #setReceiveBufferSize(int)}</td>
|
* <td>{@code "receiveBufferSize"}</td><td>{@link #setReceiveBufferSize(int)}</td>
|
||||||
* </tr><tr>
|
* </tr><tr>
|
||||||
* <td>{@code "receiveBufferSizePredictor"}</td><td>{@link #setReceiveBufferSizePredictor(ReceiveBufferSizePredictor)}</td>
|
* <td>{@code "receiveBufferSizePredictor"}</td>
|
||||||
|
* <td>{@link #setReceiveBufferSizePredictor(ReceiveBufferSizePredictor)}</td>
|
||||||
* </tr><tr>
|
* </tr><tr>
|
||||||
* <td>{@code "receiveBufferSizePredictorFactory"}</td><td>{@link #setReceiveBufferSizePredictorFactory(ReceiveBufferSizePredictorFactory)}</td>
|
* <td>{@code "receiveBufferSizePredictorFactory"}</td>
|
||||||
|
* <td>{@link #setReceiveBufferSizePredictorFactory(ReceiveBufferSizePredictorFactory)}</td>
|
||||||
* </tr><tr>
|
* </tr><tr>
|
||||||
* <td>{@code "sendBufferSize"}</td><td>{@link #setSendBufferSize(int)}</td>
|
* <td>{@code "sendBufferSize"}</td><td>{@link #setSendBufferSize(int)}</td>
|
||||||
* </tr><tr>
|
* </tr><tr>
|
||||||
@ -64,64 +66,62 @@ import org.jboss.netty.channel.ReceiveBufferSizePredictorFactory;
|
|||||||
public interface DatagramChannelConfig extends ChannelConfig {
|
public interface DatagramChannelConfig extends ChannelConfig {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_SNDBUF}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_SNDBUF} option.
|
||||||
*/
|
*/
|
||||||
int getSendBufferSize();
|
int getSendBufferSize();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_SNDBUF}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_SNDBUF} option.
|
||||||
*/
|
*/
|
||||||
void setSendBufferSize(int sendBufferSize);
|
void setSendBufferSize(int sendBufferSize);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_RCVBUF}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_RCVBUF} option.
|
||||||
*/
|
*/
|
||||||
int getReceiveBufferSize();
|
int getReceiveBufferSize();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_RCVBUF}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_RCVBUF} option.
|
||||||
*/
|
*/
|
||||||
void setReceiveBufferSize(int receiveBufferSize);
|
void setReceiveBufferSize(int receiveBufferSize);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the traffic class.
|
* Gets the {@link StandardSocketOptions#IP_TOS} option.
|
||||||
*/
|
*/
|
||||||
int getTrafficClass();
|
int getTrafficClass();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the traffic class as specified in {@link DatagramSocket#setTrafficClass(int)}.
|
* Gets the {@link StandardSocketOptions#IP_TOS} option.
|
||||||
*/
|
*/
|
||||||
void setTrafficClass(int trafficClass);
|
void setTrafficClass(int trafficClass);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_REUSEADDR}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_REUSEADDR} option.
|
||||||
*/
|
*/
|
||||||
boolean isReuseAddress();
|
boolean isReuseAddress();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_REUSEADDR}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_REUSEADDR} option.
|
||||||
*/
|
*/
|
||||||
void setReuseAddress(boolean reuseAddress);
|
void setReuseAddress(boolean reuseAddress);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_BROADCAST}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_BROADCAST} option.
|
||||||
*/
|
*/
|
||||||
boolean isBroadcast();
|
boolean isBroadcast();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_BROADCAST}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_BROADCAST} option.
|
||||||
*/
|
*/
|
||||||
void setBroadcast(boolean broadcast);
|
void setBroadcast(boolean broadcast);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the setting for local loopback of multicast datagrams.
|
* Gets the {@link StandardSocketOptions#IP_MULTICAST_LOOP} option.
|
||||||
*
|
|
||||||
* @return {@code true} if and only if the loopback mode has been disabled
|
|
||||||
*/
|
*/
|
||||||
boolean isLoopbackModeDisabled();
|
boolean isLoopbackModeDisabled();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the setting for local loopback of multicast datagrams.
|
* Sets the {@link StandardSocketOptions#IP_MULTICAST_LOOP} option.
|
||||||
*
|
*
|
||||||
* @param loopbackModeDisabled
|
* @param loopbackModeDisabled
|
||||||
* {@code true} if and only if the loopback mode has been disabled
|
* {@code true} if and only if the loopback mode has been disabled
|
||||||
@ -129,14 +129,12 @@ public interface DatagramChannelConfig extends ChannelConfig {
|
|||||||
void setLoopbackModeDisabled(boolean loopbackModeDisabled);
|
void setLoopbackModeDisabled(boolean loopbackModeDisabled);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the default time-to-live for multicast packets sent out on the
|
* Gets the {@link StandardSocketOptions#IP_MULTICAST_TTL} option.
|
||||||
* socket.
|
|
||||||
*/
|
*/
|
||||||
int getTimeToLive();
|
int getTimeToLive();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the default time-to-live for multicast packets sent out on the
|
* Sets the {@link StandardSocketOptions#IP_MULTICAST_TTL} option.
|
||||||
* {@link DatagramChannel} in order to control the scope of the multicasts.
|
|
||||||
*/
|
*/
|
||||||
void setTimeToLive(int ttl);
|
void setTimeToLive(int ttl);
|
||||||
|
|
||||||
@ -151,14 +149,12 @@ public interface DatagramChannelConfig extends ChannelConfig {
|
|||||||
void setInterface(InetAddress interfaceAddress);
|
void setInterface(InetAddress interfaceAddress);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the network interface for outgoing multicast datagrams sent on
|
* Gets the {@link StandardSocketOptions#IP_MULTICAST_IF} option.
|
||||||
* the {@link DatagramChannel}.
|
|
||||||
*/
|
*/
|
||||||
NetworkInterface getNetworkInterface();
|
NetworkInterface getNetworkInterface();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the network interface for outgoing multicast datagrams sent on
|
* Sets the {@link StandardSocketOptions#IP_MULTICAST_IF} option.
|
||||||
* the {@link DatagramChannel}.
|
|
||||||
*/
|
*/
|
||||||
void setNetworkInterface(NetworkInterface networkInterface);
|
void setNetworkInterface(NetworkInterface networkInterface);
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
package org.jboss.netty.channel.socket;
|
package org.jboss.netty.channel.socket;
|
||||||
|
|
||||||
import java.net.ServerSocket;
|
import java.net.ServerSocket;
|
||||||
|
import java.net.StandardSocketOptions;
|
||||||
|
|
||||||
import org.jboss.netty.channel.ChannelConfig;
|
import org.jboss.netty.channel.ChannelConfig;
|
||||||
|
|
||||||
@ -55,22 +56,22 @@ public interface ServerSocketChannelConfig extends ChannelConfig {
|
|||||||
void setBacklog(int backlog);
|
void setBacklog(int backlog);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_REUSEADDR}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_REUSEADDR} option.
|
||||||
*/
|
*/
|
||||||
boolean isReuseAddress();
|
boolean isReuseAddress();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_REUSEADDR}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_REUSEADDR} option.
|
||||||
*/
|
*/
|
||||||
void setReuseAddress(boolean reuseAddress);
|
void setReuseAddress(boolean reuseAddress);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_RCVBUF}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_RCVBUF} option.
|
||||||
*/
|
*/
|
||||||
int getReceiveBufferSize();
|
int getReceiveBufferSize();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_RCVBUF}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_RCVBUF} option.
|
||||||
*/
|
*/
|
||||||
void setReceiveBufferSize(int receiveBufferSize);
|
void setReceiveBufferSize(int receiveBufferSize);
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
package org.jboss.netty.channel.socket;
|
package org.jboss.netty.channel.socket;
|
||||||
|
|
||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
|
import java.net.StandardSocketOptions;
|
||||||
|
|
||||||
import org.jboss.netty.channel.ChannelConfig;
|
import org.jboss.netty.channel.ChannelConfig;
|
||||||
|
|
||||||
@ -50,72 +51,72 @@ import org.jboss.netty.channel.ChannelConfig;
|
|||||||
public interface SocketChannelConfig extends ChannelConfig {
|
public interface SocketChannelConfig extends ChannelConfig {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_TCPNODELAY}</a> option.
|
* Gets the {@link StandardSocketOptions#TCP_NODELAY} option.
|
||||||
*/
|
*/
|
||||||
boolean isTcpNoDelay();
|
boolean isTcpNoDelay();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_TCPNODELAY}</a> option.
|
* Sets the {@link StandardSocketOptions#TCP_NODELAY} option.
|
||||||
*/
|
*/
|
||||||
void setTcpNoDelay(boolean tcpNoDelay);
|
void setTcpNoDelay(boolean tcpNoDelay);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_LINGER}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_LINGER} option.
|
||||||
*/
|
*/
|
||||||
int getSoLinger();
|
int getSoLinger();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_LINGER}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_LINGER} option.
|
||||||
*/
|
*/
|
||||||
void setSoLinger(int soLinger);
|
void setSoLinger(int soLinger);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_SNDBUF}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_SNDBUF} option.
|
||||||
*/
|
*/
|
||||||
int getSendBufferSize();
|
int getSendBufferSize();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_SNDBUF}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_SNDBUF} option.
|
||||||
*/
|
*/
|
||||||
void setSendBufferSize(int sendBufferSize);
|
void setSendBufferSize(int sendBufferSize);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_RCVBUF}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_RCVBUF} option.
|
||||||
*/
|
*/
|
||||||
int getReceiveBufferSize();
|
int getReceiveBufferSize();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_RCVBUF}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_RCVBUF} option.
|
||||||
*/
|
*/
|
||||||
void setReceiveBufferSize(int receiveBufferSize);
|
void setReceiveBufferSize(int receiveBufferSize);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_KEEPALIVE}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_KEEPALIVE} option.
|
||||||
*/
|
*/
|
||||||
boolean isKeepAlive();
|
boolean isKeepAlive();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_KEEPALIVE}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_KEEPALIVE} option.
|
||||||
*/
|
*/
|
||||||
void setKeepAlive(boolean keepAlive);
|
void setKeepAlive(boolean keepAlive);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the traffic class.
|
* Gets the {@link StandardSocketOptions#IP_TOS} option.
|
||||||
*/
|
*/
|
||||||
int getTrafficClass();
|
int getTrafficClass();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the traffic class as specified in {@link Socket#setTrafficClass(int)}.
|
* Sets the {@link StandardSocketOptions#IP_TOS} option.
|
||||||
*/
|
*/
|
||||||
void setTrafficClass(int trafficClass);
|
void setTrafficClass(int trafficClass);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_REUSEADDR}</a> option.
|
* Gets the {@link StandardSocketOptions#SO_REUSEADDR} option.
|
||||||
*/
|
*/
|
||||||
boolean isReuseAddress();
|
boolean isReuseAddress();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the <a href="http://java.sun.com/javase/6/docs/technotes/guides/net/socketOpt.html">{@code SO_REUSEADDR}</a> option.
|
* Sets the {@link StandardSocketOptions#SO_REUSEADDR} option.
|
||||||
*/
|
*/
|
||||||
void setReuseAddress(boolean reuseAddress);
|
void setReuseAddress(boolean reuseAddress);
|
||||||
|
|
||||||
|
@ -100,7 +100,9 @@ abstract class AbstractNioChannel<C extends SelectableChannel & WritableByteChan
|
|||||||
|
|
||||||
final C channel;
|
final C channel;
|
||||||
|
|
||||||
protected AbstractNioChannel(Integer id, Channel parent, ChannelFactory factory, ChannelPipeline pipeline, ChannelSink sink, AbstractNioWorker worker, C ch) {
|
protected AbstractNioChannel(
|
||||||
|
Integer id, Channel parent, ChannelFactory factory, ChannelPipeline pipeline,
|
||||||
|
ChannelSink sink, AbstractNioWorker worker, C ch) {
|
||||||
super(id, parent, factory, pipeline, sink);
|
super(id, parent, factory, pipeline, sink);
|
||||||
this.worker = worker;
|
this.worker = worker;
|
||||||
this.channel = ch;
|
this.channel = ch;
|
||||||
|
@ -148,7 +148,8 @@ abstract class AbstractNioWorker implements Worker {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Start the {@link AbstractNioWorker} and return the {@link Selector} that will be used for the {@link AbstractNioChannel}'s when they get registered
|
* Start the {@link AbstractNioWorker} and return the {@link Selector} that will be used for
|
||||||
|
* the {@link AbstractNioChannel}'s when they get registered
|
||||||
*
|
*
|
||||||
* @return selector
|
* @return selector
|
||||||
*/
|
*/
|
||||||
|
@ -25,11 +25,11 @@ import org.jboss.netty.util.ExternalResourceReleasable;
|
|||||||
import org.jboss.netty.util.internal.ExecutorUtil;
|
import org.jboss.netty.util.internal.ExecutorUtil;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Abstract base class for {@link WorkerPool} implementations that create the {@link Worker}'s up-front and return them in a "fair" fashion when calling
|
* Abstract base class for {@link WorkerPool} implementations that create the {@link Worker}'s
|
||||||
* {@link #nextWorker()}
|
* up-front and return them in a "fair" fashion when calling {@link #nextWorker()}
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
public abstract class AbstractNioWorkerPool<E extends AbstractNioWorker> implements WorkerPool<E> , ExternalResourceReleasable {
|
public abstract class AbstractNioWorkerPool<E extends AbstractNioWorker>
|
||||||
|
implements WorkerPool<E>, ExternalResourceReleasable {
|
||||||
|
|
||||||
private final AbstractNioWorker[] workers;
|
private final AbstractNioWorker[] workers;
|
||||||
private final AtomicInteger workerIndex = new AtomicInteger();
|
private final AtomicInteger workerIndex = new AtomicInteger();
|
||||||
@ -39,7 +39,8 @@ public abstract class AbstractNioWorkerPool<E extends AbstractNioWorker> impleme
|
|||||||
* Create a new instance
|
* Create a new instance
|
||||||
*
|
*
|
||||||
* @param workerExecutor the {@link Executor} to use for the {@link Worker}'s
|
* @param workerExecutor the {@link Executor} to use for the {@link Worker}'s
|
||||||
* @param allowShutdownOnIdle allow the {@link Worker}'s to shutdown when there is not {@link Channel} is registered with it
|
* @param allowShutdownOnIdle allow the {@link Worker}'s to shutdown when there is not
|
||||||
|
* {@link Channel} is registered with it
|
||||||
* @param workerCount the count of {@link Worker}'s to create
|
* @param workerCount the count of {@link Worker}'s to create
|
||||||
*/
|
*/
|
||||||
AbstractNioWorkerPool(Executor workerExecutor, int workerCount, boolean allowShutDownOnIdle) {
|
AbstractNioWorkerPool(Executor workerExecutor, int workerCount, boolean allowShutDownOnIdle) {
|
||||||
@ -65,7 +66,8 @@ public abstract class AbstractNioWorkerPool<E extends AbstractNioWorker> impleme
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
* @param executor the {@link Executor} to use
|
* @param executor the {@link Executor} to use
|
||||||
* @param allowShutdownOnIdle allow the {@link Worker} to shutdown when there is not {@link Channel} is registered with it
|
* @param allowShutdownOnIdle allow the {@link Worker} to shutdown when there is not
|
||||||
|
* {@link Channel} is registered with it
|
||||||
* @return worker the new {@link Worker}
|
* @return worker the new {@link Worker}
|
||||||
*/
|
*/
|
||||||
protected abstract E createWorker(Executor executor, boolean allowShutdownOnIdle);
|
protected abstract E createWorker(Executor executor, boolean allowShutdownOnIdle);
|
||||||
|
@ -88,7 +88,8 @@ public class NioClientSocketChannelFactory implements ClientSocketChannelFactory
|
|||||||
private final NioClientSocketPipelineSink sink;
|
private final NioClientSocketPipelineSink sink;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new {@link NioClientSocketChannelFactory} which uses {@link Executors#newCachedThreadPool()} for the worker and boss executors.
|
* Creates a new {@link NioClientSocketChannelFactory} which uses {@link Executors#newCachedThreadPool()}
|
||||||
|
* for the worker and boss executors.
|
||||||
*
|
*
|
||||||
* See {@link #NioClientSocketChannelFactory(Executor, Executor)}
|
* See {@link #NioClientSocketChannelFactory(Executor, Executor)}
|
||||||
*/
|
*/
|
||||||
|
@ -130,7 +130,8 @@ public final class NioDatagramChannel extends AbstractNioChannel<DatagramChannel
|
|||||||
|
|
||||||
public ChannelFuture joinGroup(InetAddress multicastAddress) {
|
public ChannelFuture joinGroup(InetAddress multicastAddress) {
|
||||||
try {
|
try {
|
||||||
return joinGroup(multicastAddress, NetworkInterface.getByInetAddress(getLocalAddress().getAddress()), null);
|
return joinGroup(
|
||||||
|
multicastAddress, NetworkInterface.getByInetAddress(getLocalAddress().getAddress()), null);
|
||||||
} catch (SocketException e) {
|
} catch (SocketException e) {
|
||||||
return Channels.failedFuture(this, e);
|
return Channels.failedFuture(this, e);
|
||||||
}
|
}
|
||||||
@ -144,7 +145,8 @@ public final class NioDatagramChannel extends AbstractNioChannel<DatagramChannel
|
|||||||
/**
|
/**
|
||||||
* Joins the specified multicast group at the specified interface using the specified source.
|
* Joins the specified multicast group at the specified interface using the specified source.
|
||||||
*/
|
*/
|
||||||
public ChannelFuture joinGroup(InetAddress multicastAddress, NetworkInterface networkInterface, InetAddress source) {
|
public ChannelFuture joinGroup(
|
||||||
|
InetAddress multicastAddress, NetworkInterface networkInterface, InetAddress source) {
|
||||||
if (DetectionUtil.javaVersion() < 7) {
|
if (DetectionUtil.javaVersion() < 7) {
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
} else {
|
} else {
|
||||||
@ -185,7 +187,8 @@ public final class NioDatagramChannel extends AbstractNioChannel<DatagramChannel
|
|||||||
|
|
||||||
public ChannelFuture leaveGroup(InetAddress multicastAddress) {
|
public ChannelFuture leaveGroup(InetAddress multicastAddress) {
|
||||||
try {
|
try {
|
||||||
return leaveGroup(multicastAddress, NetworkInterface.getByInetAddress(getLocalAddress().getAddress()), null);
|
return leaveGroup(
|
||||||
|
multicastAddress, NetworkInterface.getByInetAddress(getLocalAddress().getAddress()), null);
|
||||||
} catch (SocketException e) {
|
} catch (SocketException e) {
|
||||||
return Channels.failedFuture(this, e);
|
return Channels.failedFuture(this, e);
|
||||||
}
|
}
|
||||||
@ -222,7 +225,8 @@ public final class NioDatagramChannel extends AbstractNioChannel<DatagramChannel
|
|||||||
while (keyIt.hasNext()) {
|
while (keyIt.hasNext()) {
|
||||||
MembershipKey key = keyIt.next();
|
MembershipKey key = keyIt.next();
|
||||||
if (networkInterface.equals(key.networkInterface())) {
|
if (networkInterface.equals(key.networkInterface())) {
|
||||||
if (source == null && key.sourceAddress() == null || source != null && source.equals(key.sourceAddress())) {
|
if (source == null && key.sourceAddress() == null ||
|
||||||
|
source != null && source.equals(key.sourceAddress())) {
|
||||||
key.drop();
|
key.drop();
|
||||||
keyIt.remove();
|
keyIt.remove();
|
||||||
}
|
}
|
||||||
|
@ -144,7 +144,8 @@ public class NioDatagramChannelFactory implements DatagramChannelFactory {
|
|||||||
* Use {@link #NioDatagramChannelFactory(WorkerPool, InternetProtocolFamily)} if unsure.
|
* Use {@link #NioDatagramChannelFactory(WorkerPool, InternetProtocolFamily)} if unsure.
|
||||||
*
|
*
|
||||||
* @param workerPool
|
* @param workerPool
|
||||||
* the {@link WorkerPool} which will be used to obtain the {@link NioDatagramWorker} that execute the I/O worker threads
|
* the {@link WorkerPool} which will be used to obtain the {@link NioDatagramWorker} that execute
|
||||||
|
* the I/O worker threads
|
||||||
*/
|
*/
|
||||||
public NioDatagramChannelFactory(WorkerPool<NioDatagramWorker> workerPool) {
|
public NioDatagramChannelFactory(WorkerPool<NioDatagramWorker> workerPool) {
|
||||||
this(workerPool, null);
|
this(workerPool, null);
|
||||||
@ -186,7 +187,8 @@ public class NioDatagramChannelFactory implements DatagramChannelFactory {
|
|||||||
* Creates a new instance.
|
* Creates a new instance.
|
||||||
*
|
*
|
||||||
* @param workerPool
|
* @param workerPool
|
||||||
* the {@link WorkerPool} which will be used to obtain the {@link Worker} that execute the I/O worker threads
|
* the {@link WorkerPool} which will be used to obtain the {@link Worker} that execute
|
||||||
|
* the I/O worker threads
|
||||||
* @param family
|
* @param family
|
||||||
* the {@link InternetProtocolFamily} to use. This should be used for UDP multicast.
|
* the {@link InternetProtocolFamily} to use. This should be used for UDP multicast.
|
||||||
* <strong>Be aware that this option is only considered when running on java7+</strong>
|
* <strong>Be aware that this option is only considered when running on java7+</strong>
|
||||||
|
@ -38,8 +38,9 @@ class NioDatagramPipelineSink extends AbstractNioChannelSink {
|
|||||||
private final WorkerPool<NioDatagramWorker> workerPool;
|
private final WorkerPool<NioDatagramWorker> workerPool;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new {@link NioDatagramPipelineSink} with a the number of {@link NioDatagramWorker}s specified in workerCount.
|
* Creates a new {@link NioDatagramPipelineSink} with a the number of {@link NioDatagramWorker}s
|
||||||
* The {@link NioDatagramWorker}s take care of reading and writing for the {@link NioDatagramChannel}.
|
* specified in workerCount. The {@link NioDatagramWorker}s take care of reading and writing
|
||||||
|
* for the {@link NioDatagramChannel}.
|
||||||
*
|
*
|
||||||
* @param workerExecutor
|
* @param workerExecutor
|
||||||
* the {@link Executor} that will run the {@link NioDatagramWorker}s
|
* the {@link Executor} that will run the {@link NioDatagramWorker}s
|
||||||
|
@ -90,7 +90,8 @@ public class NioServerSocketChannelFactory implements ServerSocketChannelFactory
|
|||||||
private final ChannelSink sink;
|
private final ChannelSink sink;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new {@link NioServerSocketChannelFactory} using {@link Executors#newCachedThreadPool()} for the boss and worker.
|
* Create a new {@link NioServerSocketChannelFactory} using {@link Executors#newCachedThreadPool()}
|
||||||
|
* for the boss and worker.
|
||||||
*
|
*
|
||||||
* See {@link #NioServerSocketChannelFactory(Executor, Executor)}
|
* See {@link #NioServerSocketChannelFactory(Executor, Executor)}
|
||||||
*/
|
*/
|
||||||
@ -136,7 +137,8 @@ public class NioServerSocketChannelFactory implements ServerSocketChannelFactory
|
|||||||
* @param bossExecutor
|
* @param bossExecutor
|
||||||
* the {@link Executor} which will execute the boss threads
|
* the {@link Executor} which will execute the boss threads
|
||||||
* @param workerPool
|
* @param workerPool
|
||||||
* the {@link WorkerPool} which will be used to obtain the {@link NioWorker} that execute the I/O worker threads
|
* the {@link WorkerPool} which will be used to obtain the {@link NioWorker} that execute
|
||||||
|
* the I/O worker threads
|
||||||
*/
|
*/
|
||||||
public NioServerSocketChannelFactory(
|
public NioServerSocketChannelFactory(
|
||||||
Executor bossExecutor, WorkerPool<NioWorker> workerPool) {
|
Executor bossExecutor, WorkerPool<NioWorker> workerPool) {
|
||||||
|
@ -42,9 +42,11 @@ import org.jboss.netty.channel.socket.SocketChannelConfig;
|
|||||||
* </tr><tr>
|
* </tr><tr>
|
||||||
* <td>{@code "writeSpinCount"}</td><td>{@link #setWriteSpinCount(int)}</td>
|
* <td>{@code "writeSpinCount"}</td><td>{@link #setWriteSpinCount(int)}</td>
|
||||||
* </tr><tr>
|
* </tr><tr>
|
||||||
* <td>{@code "receiveBufferSizePredictor"}</td><td>{@link #setReceiveBufferSizePredictor(ReceiveBufferSizePredictor)}</td>
|
* <td>{@code "receiveBufferSizePredictor"}</td>
|
||||||
|
* <td>{@link #setReceiveBufferSizePredictor(ReceiveBufferSizePredictor)}</td>
|
||||||
* </tr><tr>
|
* </tr><tr>
|
||||||
* <td>{@code "receiveBufferSizePredictorFactory"}</td><td>{@link #setReceiveBufferSizePredictorFactory(ReceiveBufferSizePredictorFactory)}</td>
|
* <td>{@code "receiveBufferSizePredictorFactory"}</td>
|
||||||
|
* <td>{@link #setReceiveBufferSizePredictorFactory(ReceiveBufferSizePredictorFactory)}</td>
|
||||||
* </tr>
|
* </tr>
|
||||||
* </table>
|
* </table>
|
||||||
*/
|
*/
|
||||||
|
@ -19,8 +19,9 @@ import org.jboss.netty.channel.socket.Worker;
|
|||||||
import org.jboss.netty.util.ExternalResourceReleasable;
|
import org.jboss.netty.util.ExternalResourceReleasable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This implementation of a {@link WorkerPool} should be used if you plan to share a {@link WorkerPool} between different Factories. You will need to call {@link #destroy()} by your own once
|
* This implementation of a {@link WorkerPool} should be used if you plan to share a
|
||||||
* you want to release any resources of it.
|
* {@link WorkerPool} between different Factories. You will need to call {@link #destroy()} by your
|
||||||
|
* own once you want to release any resources of it.
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@ -27,7 +27,6 @@ import org.jboss.netty.buffer.ChannelBuffer;
|
|||||||
import org.jboss.netty.buffer.CompositeChannelBuffer;
|
import org.jboss.netty.buffer.CompositeChannelBuffer;
|
||||||
import org.jboss.netty.channel.DefaultFileRegion;
|
import org.jboss.netty.channel.DefaultFileRegion;
|
||||||
import org.jboss.netty.channel.FileRegion;
|
import org.jboss.netty.channel.FileRegion;
|
||||||
import org.jboss.netty.util.internal.DetectionUtil;
|
|
||||||
|
|
||||||
final class SocketSendBufferPool {
|
final class SocketSendBufferPool {
|
||||||
|
|
||||||
@ -368,7 +367,8 @@ final class SocketSendBufferPool {
|
|||||||
public void release() {
|
public void release() {
|
||||||
if (file instanceof DefaultFileRegion) {
|
if (file instanceof DefaultFileRegion) {
|
||||||
if (((DefaultFileRegion) file).releaseAfterTransfer()) {
|
if (((DefaultFileRegion) file).releaseAfterTransfer()) {
|
||||||
// Make sure the FileRegion resource are released otherwise it may cause a FD leak or something similar
|
// Make sure the FileRegion resource are released otherwise it may cause a FD
|
||||||
|
// leak or something similar
|
||||||
file.releaseExternalResources();
|
file.releaseExternalResources();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -134,10 +134,12 @@ abstract class AbstractOioWorker<C extends AbstractOioChannel> implements Worker
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Process the incoming messages and also is responsible for call {@link Channels#fireMessageReceived(Channel, Object)} once a message
|
* Process the incoming messages and also is responsible for call
|
||||||
* was processed without errors.
|
* {@link Channels#fireMessageReceived(Channel, Object)} once a message was processed without
|
||||||
|
* errors.
|
||||||
*
|
*
|
||||||
* @return continue returns <code>true</code> as long as this worker should continue to try processing incoming messages
|
* @return continue returns <code>true</code> as long as this worker should continue to try
|
||||||
|
* processing incoming messages
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
abstract boolean process() throws IOException;
|
abstract boolean process() throws IOException;
|
||||||
|
@ -91,7 +91,8 @@ public class OioServerSocketChannelFactory implements ServerSocketChannelFactory
|
|||||||
private final ChannelSink sink;
|
private final ChannelSink sink;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new {@link OioServerSocketChannelFactory} with a {@link Executors#newCachedThreadPool()} for the boss and worker executor.
|
* Create a new {@link OioServerSocketChannelFactory} with a {@link Executors#newCachedThreadPool()}
|
||||||
|
* for the boss and worker executor.
|
||||||
*
|
*
|
||||||
* See {@link #OioServerSocketChannelFactory(Executor, Executor)}
|
* See {@link #OioServerSocketChannelFactory(Executor, Executor)}
|
||||||
*/
|
*/
|
||||||
|
@ -94,8 +94,8 @@ class OioWorker extends AbstractOioWorker<OioSocketChannel> {
|
|||||||
try {
|
try {
|
||||||
int length = 0;
|
int length = 0;
|
||||||
|
|
||||||
// Add support to write a FileRegion. This in fact will not give any performance gain but at least it not fail and
|
// Add support to write a FileRegion. This in fact will not give any performance gain
|
||||||
// we did the best to emulate it
|
// but at least it not fail and we did the best to emulate it
|
||||||
if (message instanceof FileRegion) {
|
if (message instanceof FileRegion) {
|
||||||
FileRegion fr = (FileRegion) message;
|
FileRegion fr = (FileRegion) message;
|
||||||
try {
|
try {
|
||||||
|
@ -415,8 +415,8 @@ public class MemoryAwareThreadPoolExecutor extends ThreadPoolExecutor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns if the {@link ChannelFuture}'s of the {@link ChannelEventRunnable}'s should be notified about the shutdown of this {@link MemoryAwareThreadPoolExecutor}.
|
* Returns if the {@link ChannelFuture}'s of the {@link ChannelEventRunnable}'s should be
|
||||||
*
|
* notified about the shutdown of this {@link MemoryAwareThreadPoolExecutor}.
|
||||||
*/
|
*/
|
||||||
public boolean getNotifyChannelFuturesOnShutdown() {
|
public boolean getNotifyChannelFuturesOnShutdown() {
|
||||||
return notifyOnShutdown;
|
return notifyOnShutdown;
|
||||||
|
@ -55,8 +55,9 @@ public final class QueueFactory {
|
|||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
// For whatever reason an exception was thrown while loading the LinkedTransferQueue
|
// For whatever reason an exception was thrown while loading the LinkedTransferQueue
|
||||||
//
|
//
|
||||||
// This mostly happens because of a custom classloader or security policy that did not allow us to access the
|
// This mostly happens because of a custom classloader or security policy that did not
|
||||||
// com.sun.Unmisc class. So just log it and fallback to the old LegacyLinkedTransferQueue that works in all cases
|
// allow us to access the com.sun.Unmisc class. So just log it and fallback to the old
|
||||||
|
// LegacyLinkedTransferQueue that works in all cases
|
||||||
if (LOGGER.isDebugEnabled()) {
|
if (LOGGER.isDebugEnabled()) {
|
||||||
LOGGER.debug("Unable to instance LinkedTransferQueue, fallback to LegacyLinkedTransferQueue", t);
|
LOGGER.debug("Unable to instance LinkedTransferQueue, fallback to LegacyLinkedTransferQueue", t);
|
||||||
}
|
}
|
||||||
@ -87,8 +88,9 @@ public final class QueueFactory {
|
|||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
// For whatever reason an exception was thrown while loading the LinkedTransferQueue
|
// For whatever reason an exception was thrown while loading the LinkedTransferQueue
|
||||||
//
|
//
|
||||||
// This mostly happens because of a custom classloader or security policy that did not allow us to access the
|
// This mostly happens because of a custom classloader or security policy that did not
|
||||||
// com.sun.Unmisc class. So just log it and fallback to the old LegacyLinkedTransferQueue that works in all cases
|
// allow us to access the com.sun.Unmisc class. So just log it and fallback to the old
|
||||||
|
// LegacyLinkedTransferQueue that works in all cases
|
||||||
if (LOGGER.isDebugEnabled()) {
|
if (LOGGER.isDebugEnabled()) {
|
||||||
LOGGER.debug("Unable to instance LinkedTransferQueue, fallback to LegacyLinkedTransferQueue", t);
|
LOGGER.debug("Unable to instance LinkedTransferQueue, fallback to LegacyLinkedTransferQueue", t);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user