package org.openamq.client.transport; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.apache.mina.common.ConnectFuture; import org.apache.mina.common.ByteBuffer; import org.apache.mina.common.SimpleByteBufferAllocator; import org.apache.mina.transport.socket.nio.SocketSessionConfig; import org.apache.mina.transport.socket.nio.SocketConnectorConfig; import org.openamq.client.AMQConnection; import org.openamq.client.protocol.AMQProtocolHandler; import org.openamq.pool.ReadWriteThreadModel; import org.openamq.bio.SocketConnector; import java.io.IOException; import java.net.InetSocketAddress; public class BlockingSocketTransportConnection implements ITransportConnection { private static final Logger _logger = LoggerFactory.getLogger(BlockingSocketTransportConnection.class); public void connect(AMQProtocolHandler protocolHandler, AMQConnection.BrokerDetail brokerDetail) throws IOException { ByteBuffer.setUseDirectBuffers(Boolean.getBoolean("amqj.enableDirectBuffers")); // the MINA default is currently to use the pooled allocator although this may change in future // once more testing of the performance of the simple allocator has been done if (!Boolean.getBoolean("amqj.enablePooledAllocator")) { ByteBuffer.setAllocator(new SimpleByteBufferAllocator()); } final SocketConnector ioConnector = new SocketConnector(); SocketConnectorConfig cfg = (SocketConnectorConfig) ioConnector.getDefaultConfig(); // if we do not use our own thread model we get the MINA default which is to use // its own leader-follower model boolean readWriteThreading = Boolean.getBoolean("amqj.shared_read_write_pool"); if (readWriteThreading) { cfg.setThreadModel(new ReadWriteThreadModel()); } SocketSessionConfig scfg = (SocketSessionConfig) cfg.getSessionConfig(); scfg.setTcpNoDelay("true".equalsIgnoreCase(System.getProperty("amqj.tcpNoDelay", "true"))); scfg.setSendBufferSize(Integer.getInteger("amqj.sendBufferSize", 32768)); scfg.setReceiveBufferSize(Integer.getInteger("amqj.receiveBufferSize", 32768)); final InetSocketAddress address = new InetSocketAddress(brokerDetail.host, brokerDetail.port); _logger.info("Attempting connection to " + address.getHostName() + ":" + Integer.toString(address.getPort())); ConnectFuture future = ioConnector.connect(address, protocolHandler); // wait for connection to complete future.join(); // we call getSession which throws an IOException if there has been an error connecting future.getSession(); } }