Package com.rabbitmq.client.impl
Class SocketFrameHandler
java.lang.Object
com.rabbitmq.client.impl.SocketFrameHandler
- All Implemented Interfaces:
FrameHandler
,NetworkConnection
A socket-based frame handler.
-
Field Summary
Modifier and TypeFieldDescriptionstatic final int
Time to linger before closing the socket forcefully. -
Constructor Summary
ConstructorDescriptionSocketFrameHandler
(Socket socket) SocketFrameHandler
(Socket socket, ExecutorService shutdownExecutor, int maxInboundMessageBodySize) -
Method Summary
Modifier and TypeMethodDescriptionvoid
close()
Close the underlying data connection (complaint not permitted).void
flush()
Flush the underlying data connection.Retrieve address of peer.Retrieve the local host.int
Retrieve the local port number.int
getPort()
Retrieve port number of peer.int
Get the underlying socket's read timeout in milliseconds.void
initialize
(AMQConnection connection) Read aFrame
from the underlying data connection.void
Send the initial connection header, thus kickstarting the AMQP protocol version negotiation process and putting the underlying connection in a state such that the next layer of startup can proceed.void
sendHeader
(int major, int minor) Write a 0-8-style connection header to the underlying socket, containing the specified version information, kickstarting the AMQP protocol version negotiation process.void
sendHeader
(int major, int minor, int revision) Write a 0-9-1-style connection header to the underlying socket, containing the specified version information, kickstarting the AMQP protocol version negotiation process.void
setTimeout
(int timeoutMs) Set the underlying socket's read timeout in milliseconds, if applicable.void
writeFrame
(Frame frame) Write aFrame
to the underlying data connection.
-
Field Details
-
SOCKET_CLOSING_TIMEOUT
public static final int SOCKET_CLOSING_TIMEOUTTime to linger before closing the socket forcefully.- See Also:
-
-
Constructor Details
-
SocketFrameHandler
- Parameters:
socket
- the socket to use- Throws:
IOException
-
SocketFrameHandler
public SocketFrameHandler(Socket socket, ExecutorService shutdownExecutor, int maxInboundMessageBodySize) throws IOException - Parameters:
socket
- the socket to use- Throws:
IOException
-
-
Method Details
-
getAddress
Description copied from interface:NetworkConnection
Retrieve address of peer.- Specified by:
getAddress
in interfaceNetworkConnection
-
getLocalAddress
Description copied from interface:NetworkConnection
Retrieve the local host.- Specified by:
getLocalAddress
in interfaceNetworkConnection
- Returns:
- the client socket address.
-
getInputStream
-
getPort
public int getPort()Description copied from interface:NetworkConnection
Retrieve port number of peer.- Specified by:
getPort
in interfaceNetworkConnection
-
getLocalPort
public int getLocalPort()Description copied from interface:NetworkConnection
Retrieve the local port number.- Specified by:
getLocalPort
in interfaceNetworkConnection
- Returns:
- the client socket port number
-
setTimeout
Description copied from interface:FrameHandler
Set the underlying socket's read timeout in milliseconds, if applicable.- Specified by:
setTimeout
in interfaceFrameHandler
- Parameters:
timeoutMs
- The timeout in milliseconds- Throws:
SocketException
-
getTimeout
Description copied from interface:FrameHandler
Get the underlying socket's read timeout in milliseconds.- Specified by:
getTimeout
in interfaceFrameHandler
- Returns:
- The timeout in milliseconds
- Throws:
SocketException
-
sendHeader
Write a 0-8-style connection header to the underlying socket, containing the specified version information, kickstarting the AMQP protocol version negotiation process.- Parameters:
major
- major protocol version numberminor
- minor protocol version number- Throws:
IOException
- if there is a problem accessing the connection- See Also:
-
sendHeader
Write a 0-9-1-style connection header to the underlying socket, containing the specified version information, kickstarting the AMQP protocol version negotiation process.- Parameters:
major
- major protocol version numberminor
- minor protocol version numberrevision
- protocol revision number- Throws:
IOException
- if there is a problem accessing the connection- See Also:
-
sendHeader
Description copied from interface:FrameHandler
Send the initial connection header, thus kickstarting the AMQP protocol version negotiation process and putting the underlying connection in a state such that the next layer of startup can proceed.- Specified by:
sendHeader
in interfaceFrameHandler
- Throws:
IOException
- if there is a problem accessing the connection
-
initialize
- Specified by:
initialize
in interfaceFrameHandler
-
readFrame
Description copied from interface:FrameHandler
Read aFrame
from the underlying data connection.- Specified by:
readFrame
in interfaceFrameHandler
- Returns:
- an incoming Frame, or null if there is none
- Throws:
IOException
- if there is a problem accessing the connection
-
writeFrame
Description copied from interface:FrameHandler
Write aFrame
to the underlying data connection.- Specified by:
writeFrame
in interfaceFrameHandler
- Parameters:
frame
- the Frame to transmit- Throws:
IOException
- if there is a problem accessing the connection
-
flush
Description copied from interface:FrameHandler
Flush the underlying data connection.- Specified by:
flush
in interfaceFrameHandler
- Throws:
IOException
- if there is a problem accessing the connection
-
close
public void close()Description copied from interface:FrameHandler
Close the underlying data connection (complaint not permitted).- Specified by:
close
in interfaceFrameHandler
-