package org.openamq.fragmentation;
import org.apache.log4j.Logger;
import org.openamq.client.AMQConnection;
import org.openamq.AMQException;
import org.openamq.client.AMQTopic;
import org.openamq.jms.MessageProducer;
import org.openamq.jms.Session;
import javax.jms.*;
import java.net.InetAddress;
import java.net.UnknownHostException;
/**
* A client that behaves as follows:
* <ul><li>Connects to a queue, whose name is specified as a cmd-line argument</li>
* <li>Creates a temporary queue</li>
* <li>Creates messages containing a property that is the name of the temporary queue</li>
* <li>Fires off a message on the original queue and waits for a response on the temporary queue</li>
* </ul>
*
*/
public class TestLargePublisher
{
private static final Logger _log = Logger.getLogger(TestLargePublisher.class);
private AMQConnection _connection;
private Session _session;
private class CallbackHandler implements MessageListener
{
private int _expectedMessageCount;
private int _actualMessageCount;
private long _startTime;
public CallbackHandler(int expectedMessageCount, long startTime)
{
_expectedMessageCount = expectedMessageCount;
_startTime = startTime;
}
public void onMessage(Message m)
{
if (_log.isDebugEnabled())
{
_log.debug("Message received: " + m);
}
_actualMessageCount++;
if (_actualMessageCount%1000 == 0)
{
_log.info("Received message count: " + _actualMessageCount);
}
/*if (!"henson".equals(m.toString()))
{
_log.error("AbstractJMSMessage response not correct: expected 'henson' but got " + m.toString());
}
else
{
if (_log.isDebugEnabled())
{
_log.debug("AbstractJMSMessage " + m + " received");
}
else
{
_log.info("AbstractJMSMessage received");
}
} */
if (_actualMessageCount == _expectedMessageCount)
{
long timeTaken = System.currentTimeMillis() - _startTime;
System.out.println("Total time taken to receive " + _expectedMessageCount+ " messages was " +
timeTaken + "ms, equivalent to " +
(_expectedMessageCount/(timeTaken/1000.0)) + " messages per second");
}
}
}
public TestLargePublisher(String host, int port, String clientID,
final int messageCount) throws AMQException
{
try
{
createConnection(host, port, clientID);
_session = (Session) _connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
AMQTopic destination = new AMQTopic("large");
MessageProducer producer = (MessageProducer) _session.createProducer(destination);
_connection.start();
//TextMessage msg = _session.createTextMessage(tempDestination.getQueueName() + "/Presented to in conjunction with Mahnah Mahnah and the Snowths");
final long startTime = System.currentTimeMillis();
for (int i = 0; i < messageCount; i++)
{
BytesMessage msg = _session.createBytesMessage();
populateMessage(msg);
producer.send(msg);
}
_log.info("Finished sending " + messageCount + " messages");
}
catch (JMSException e)
{
e.printStackTrace();
}
}
private void createConnection(String host, int port, String clientID) throws AMQException
{
_connection = new AMQConnection(host, port, "guest", "guest",
clientID, "/test");
}
private void populateMessage(BytesMessage msg) throws JMSException
{
int size = 1024 * 187; // 187k
byte[] data = new byte[size];
for (int i = 0; i < data.length; i++)
{
data[i] = (byte)(i%25);
}
msg.writeBytes(data);
}
/**
*
* @param args argument 1 if present specifies the name of the temporary queue to create. Leaving it blank
* means the server will allocate a name.
*/
public static void main(String[] args)
{
if (args.length == 0)
{
System.err.println("Usage: TestLargePublisher <host> <port> <number of messages>");
}
try
{
int port = Integer.parseInt(args[1]);
InetAddress address = InetAddress.getLocalHost();
String clientID = address.getHostName() + System.currentTimeMillis();
TestLargePublisher client = new TestLargePublisher(args[0], port, clientID, Integer.parseInt(args[2]));
}
catch (UnknownHostException e)
{
e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates.
}
catch (AMQException e)
{
System.err.println("Error in client: " + e);
e.printStackTrace();
}
//System.exit(0);
}
}