public class DefaultTcpTransportMapping extends TcpTransportMapping
DefaultTcpTransportMapping implements a TCP transport
mapping with the Java 1.4 new IO API.
It uses a single thread for processing incoming and outgoing messages.
The thread is started when the listen method is called, or
when an outgoing request is sent using the sendMessage method.| Modifier and Type | Class and Description |
|---|---|
protected class |
DefaultTcpTransportMapping.ServerThread |
static class |
DefaultTcpTransportMapping.SnmpMesssageLengthDecoder |
| Modifier and Type | Field and Description |
|---|---|
static int |
DEFAULT_MAX_BUSY_LOOPS
The maximum number of loops trying to read data from an incoming port but no data has been received.
|
protected MessageLengthDecoder |
messageLengthDecoder |
protected WorkerTask |
server |
protected DefaultTcpTransportMapping.ServerThread |
serverThread |
protected CommonTimer |
socketCleaner |
protected Map<Address,org.snmp4j.transport.DefaultTcpTransportMapping.SocketEntry> |
sockets |
openSocketOnSending, suspendedAddresses, tcpAddressasyncMsgProcessingSupported, maxInboundMessageSize, transportListener| Constructor and Description |
|---|
DefaultTcpTransportMapping()
Creates a default TCP transport mapping with the server for incoming
messages disabled.
|
DefaultTcpTransportMapping(TcpAddress serverAddress)
Creates a default TCP transport mapping that binds to the given address
(interface) on the local host.
|
| Modifier and Type | Method and Description |
|---|---|
protected void |
addBufferToReadBuffer(org.snmp4j.transport.DefaultTcpTransportMapping.SocketEntry entry,
ByteBuffer byteBuffer) |
void |
close()
Closes all open sockets and stops the internal server thread that
processes messages and removes all queued requests and socket entries.
|
boolean |
close(TcpAddress remoteAddress)
Closes a connection to the supplied remote address, if it is open.
|
long |
getConnectionTimeout()
Gets the connection timeout.
|
TcpAddress |
getListenAddress()
Returns the address that represents the actual incoming address this transport
mapping uses to listen for incoming packets.
|
protected int |
getMaxBusyLoops() |
int |
getMaxInboundMessageSize()
Gets the inbound buffer size for incoming requests.
|
MessageLengthDecoder |
getMessageLengthDecoder()
Returns the
MessageLengthDecoder used by this transport
mapping. |
int |
getPriority()
Returns the priority of the internal listen thread.
|
String |
getThreadName()
Returns the name of the listen thread.
|
boolean |
isListening()
Returns
true if the transport mapping is listening for
incoming messages. |
boolean |
isServerEnabled()
Checks whether a server for incoming requests is enabled.
|
void |
listen()
Listen for incoming and outgoing requests.
|
protected Object |
removeSocketEntry(TcpAddress incomingAddress) |
void |
sendMessage(TcpAddress address,
byte[] message,
TransportStateReference tmStateReference)
Sends a SNMP message to the supplied address.
|
void |
setConnectionTimeout(long connectionTimeout)
Sets the connection timeout.
|
protected void |
setMaxBusyLoops(int maxBusyLoops) |
void |
setMaxInboundMessageSize(int maxInboundMessageSize)
Sets the maximum buffer size for incoming requests.
|
void |
setMessageLengthDecoder(MessageLengthDecoder messageLengthDecoder)
Sets the message length decoder.
|
void |
setPriority(int newPriority)
Changes the priority of the server thread for this TCP transport mapping.
|
void |
setServerEnabled(boolean serverEnabled)
Sets whether a server for incoming requests should be created when
the transport is set into listen state.
|
protected void |
setSocketOptions(ServerSocket serverSocket)
Sets optional server socket options.
|
void |
setThreadName(String name)
Sets the name of the listen thread for this UDP transport mapping.
|
protected void |
socketClosedRemotely(SelectionKey sk,
SocketChannel readChannel,
TcpAddress incomingAddress) |
addTransportStateListener, fireConnectionStateChanged, getAddress, getSupportedAddressClass, handleDroppedMessageToSend, isOpenSocketOnSending, removeTransportStateListener, resumeAddress, setOpenSocketOnSending, suspendAddressaddTransportListener, fireProcessMessage, isAsyncMsgProcessingSupported, removeTransportListener, setAsyncMsgProcessingSupportedclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitaddTransportListener, removeTransportListenerpublic static final int DEFAULT_MAX_BUSY_LOOPS
protected WorkerTask server
protected DefaultTcpTransportMapping.ServerThread serverThread
protected CommonTimer socketCleaner
protected MessageLengthDecoder messageLengthDecoder
public DefaultTcpTransportMapping()
throws IOException
IOException - on failure of binding a local port.public DefaultTcpTransportMapping(TcpAddress serverAddress) throws IOException
serverAddress - the TcpAddress instance that describes the server address to listen
on incoming connection requests.IOException - if the given address cannot be bound.public void listen()
throws IOException
serverEnabled
member is false the server for incoming requests is not
started. This starts the internal server thread that processes messages.listen in interface TransportMapping<TcpAddress>listen in class TcpTransportMappingSocketException - when the transport is already listening for incoming/outgoing messages.IOException - if the listen port could not be bound to the server thread.public void setPriority(int newPriority)
listen() has been
called for this transport mapping or if SNMP4J is configured to use
a non-default thread factory.newPriority - the new priority.Thread.setPriority(int)public int getPriority()
Thread.MIN_PRIORITY and
Thread.MAX_PRIORITY.public void setThreadName(String name)
listen() has been
called for this transport mapping.name - the new thread name.public String getThreadName()
null.public void close()
close in interface TransportMapping<TcpAddress>close in class TcpTransportMappingpublic boolean close(TcpAddress remoteAddress) throws IOException
remoteAddress - the address of the peer socket.true if the connection has been closed and
false if there was nothing to close.IOException - if the remote address cannot be closed due to an IO exception.public void sendMessage(TcpAddress address, byte[] message, TransportStateReference tmStateReference) throws IOException
sendMessage in interface TransportMapping<TcpAddress>sendMessage in class TcpTransportMappingaddress - an TcpAddress. A ClassCastException is thrown
if address is not a TcpAddress instance.message - byte[]
the message to sent.tmStateReference - the (optional) transport model state reference as defined by
RFC 5590 section 6.1.IOException - if an IO exception occurs while trying to send the message.public long getConnectionTimeout()
public void setConnectionTimeout(long connectionTimeout)
setConnectionTimeout in interface ConnectionOrientedTransportMapping<TcpAddress>setConnectionTimeout in class TcpTransportMappingconnectionTimeout - the idle timeout in milliseconds. A zero or negative value will disable
any timeout and connections opened by this transport mapping will stay
opened until they are explicitly closed.public boolean isServerEnabled()
public MessageLengthDecoder getMessageLengthDecoder()
TcpTransportMappingMessageLengthDecoder used by this transport
mapping.getMessageLengthDecoder in interface ConnectionOrientedTransportMapping<TcpAddress>getMessageLengthDecoder in class TcpTransportMappingpublic void setServerEnabled(boolean serverEnabled)
listen() method is called (if the transport is already
listening, close() has to be called before).serverEnabled - if true if the transport will listens for incoming
requests after listen() has been called.public void setMessageLengthDecoder(MessageLengthDecoder messageLengthDecoder)
DefaultTcpTransportMapping.SnmpMesssageLengthDecoder. The message length decoder must be
able to decode the total length of a message for this transport mapping
protocol(s).setMessageLengthDecoder in interface ConnectionOrientedTransportMapping<TcpAddress>setMessageLengthDecoder in class TcpTransportMappingmessageLengthDecoder - a MessageLengthDecoder instance.public int getMaxInboundMessageSize()
getMaxInboundMessageSize in interface TransportMapping<TcpAddress>getMaxInboundMessageSize in class AbstractTransportMapping<TcpAddress>public void setMaxInboundMessageSize(int maxInboundMessageSize)
maxInboundMessageSize - the length of the inbound buffer in bytes.public boolean isListening()
TransportMappingtrue if the transport mapping is listening for
incoming messages. For connection oriented transport mappings this
is a prerequisite to be able to send SNMP messages. For connectionless
transport mappings it is a prerequisite to be able to receive responses.true if this transport mapping is listening for messages.protected int getMaxBusyLoops()
protected void setMaxBusyLoops(int maxBusyLoops)
protected void setSocketOptions(ServerSocket serverSocket)
serverSocket - the ServerSocket to apply additional non-default options.public TcpAddress getListenAddress()
TransportMappinggetListenAddress in interface TransportMapping<TcpAddress>getListenAddress in class TcpTransportMappingnull this transport
mapping is not configured to listen for incoming packets.protected void addBufferToReadBuffer(org.snmp4j.transport.DefaultTcpTransportMapping.SocketEntry entry,
ByteBuffer byteBuffer)
protected void socketClosedRemotely(SelectionKey sk, SocketChannel readChannel, TcpAddress incomingAddress) throws IOException
IOExceptionprotected Object removeSocketEntry(TcpAddress incomingAddress)
Copyright © 2020 SNMP4J.org. All rights reserved.