简体   繁体   中英

How to monitor multiple JMS queues

My application needs to monitor multiple JMS queue's.

How should this be done? Start 2 threads? Can 2 queues be monitored at the same time?

Sample code for one queue:

...
queue1 = session.createQueue("queue-1");
consumer = session.createConsumer(queue1);

connection.start();

while (true) {
    Message m = consumer.receive(10000);

    if (m == null) {
        ...nothing...
    } else {
        ...do something with the message...
    }
}
...

How should I watch queue-1 and queue-2?

You could use quartz scheduler Quartz Scheduler for this. Implement one (or more) quartz job(s) like this:

public class MessageReaderJob1 implements Job {
private QueueReader1 qr;
@Override
public synchronized void execute(JobExecutionContext arg0) throws JobExecutionException {
    qr = QueueReader1.getInstance();

    try {
        Message message = qr.getConsumer().receiveNoWait();
        ....
    }
}

Then you will need a scheduler that you will run from your application (main method or servlet), note that you can implement a different trigger for the second queue also:

public class TestCasesSchedule {

private Scheduler scheduler;

public void createSchedule() {
    JobDetail job1 = JobBuilder.newJob(MessageReaderJob1.class)
            .withIdentity("jobname", Scheduler.DEFAULT_GROUP)
            .build();

    JobDetail job2 = JobBuilder.newJob(MessageReaderJob2.class)
            .withIdentity("jobname", Scheduler.DEFAULT_GROUP)
            .build();

    Trigger trigger = TriggerBuilder.newTrigger()
            .withIdentity("minutestrigger", "triggergroup")
            .startNow()
            .withSchedule(SimpleScheduleBuilder.simpleSchedule()
                    .withIntervalInMinutes(5)
                    .repeatForever())
            .build();

    try {
        SchedulerFactory sf = new StdSchedulerFactory();
        scheduler = sf.getScheduler();
        scheduler.start();
        scheduler.scheduleJob(job1, trigger);
        scheduler.scheduleJob(job2, trigger);
    } catch (SchedulerException se) {
        System.err.println(se.getMessage())
    }
}

QueueReader for one of your queue's would look like this:

public class QueueReader1 {

private MessageConsumer consumer = null;
private Context jndiContext = null;
private QueueConnectionFactory queueConnectionFactory = null;
private QueueConnection queueConnection = null;
private QueueSession queueSession = null;
private Queue queue = null;

private static final QueueReader instance = new QueueReader();

public synchronized static QueueReader getInstance() {
    return instance;
}

private QueueReader() {

    /*
     * Create a JNDI API InitialContext object if none exists
     * yet.
     */
     try {
        jndiContext = new InitialContext();


    } catch (NamingException e) {
        System.err.println(e.getMessage())
        System.exit(1);
    }

    /*
     * Look up connection factory and queue.  If either does
     * not exist, exit.
     */
    try {
        queueConnectionFactory = (QueueConnectionFactory) jndiContext.lookup("connection_factory_name");
        queue = (Queue) jndiContext.lookup("queue_name");
        queueConnection =
                queueConnectionFactory.createQueueConnection();
        queueSession =
                queueConnection.createQueueSession(false,
                Session.AUTO_ACKNOWLEDGE);

        consumer = queueSession.createConsumer(queue);

        queueConnection.start();

    } catch (JMSException ex) {
         System.err.println(ex.getMessage());
    } catch (NamingException e) {
         System.err.println(e.getMessage());
    }
}

}

This is my solution. It works. Any extra advise is welcome!

Main class:

public class Notifier {
    public static void main(String[] args) throws Exception {
        // Start a thread for each JMQ queue to monitor.
        DestinationThread destination1 = new DestinationThread("queue1");
        DestinationThread destination2 = new DestinationThread("queue2");
        destination1.start();
        destination2.start();
    }
}

The Thread:

public class DestinationThread extends Thread {

    private String destinationQueue;

    private static ActiveMQConnectionFactory connectionFactory = null;
    private static Connection connection = null;
    private static Session session = null;
    private static Destination destination = null;
    private static MessageConsumer consumer = null;

    public DestinationThread(String destinationQueue) {
        this.destinationQueue = destinationQueue;
    }

    @Override
    public void run() {
        try {
                initializeThread(destinationQueue);
                startThread(destinationQueue);
        } catch (Exception e) {
            //TODO
        }
    }

    private void initializeThread(String destinationQueue) {
        boolean connectionMade = false;
        while (!connectionMade) {
            try {
                connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616");
                connection = connectionFactory.createConnection();
                connection.start();
                session = connection.createSession(false,Session.AUTO_ACKNOWLEDGE);
                destination = session.createQueue(destinationQueue);
                consumer = session.createConsumer(destination);
                connectionMade = true;
            } catch (JMSException e) {
                //TODO
                try {
                    Thread.sleep(30000);
                } catch (InterruptedException ie) {
                }
            }
        }
    }


    private void startThreadOther(String destinationQueue) throws Exception {
        while (true) {
            try {
                Message message = consumer.receive(300000);
                if (message == null) {
                    //No message received for 5 minutes - Re-initializing the connection
                    initializeThread(destinationQueue);
                } else if (message instanceof TextMessage) {
                    if (destinationQueue.equals("queue1") {
                        //Message received from queue1 - do something with it
                    } else if (destinationQueue.equals("queue2") {
                        //Message received from queue2 - do something with it
                    } else {
                        //nothing
                    }
                } else {
                    //nothing
                }
            } catch (Exception e) {
                //TODO
            }
        }
    }
}

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM