JMS is an integral part of many SOA/Integration projects.
Like any other resource, we want scalability and reliability for our JMS artifacts.
So here is a simple example based on the following simple WLS cluster I've set up
data:image/s3,"s3://crabby-images/955df/955df8ac2df840bcbd42f669053980e431471b83" alt=""
Example 1: Using a UDD(Uniform distributed destination)
Thanks to my colleague Santosh for his support here.
UDDs make sense for both reliability and scalability. Essentially the UDD Queue
will be deployed to my cluster and thus available on both of my managed servers.
Step 1 -Create a JMS Server (JMSServer1)
-- FileStore= JMSFileStore1
-- Target= MgdServer1(Migratable)
data:image/s3,"s3://crabby-images/b0d95/b0d95ae5c7e8b24ee8bc3361c6dc7abf54db1234" alt=""
data:image/s3,"s3://crabby-images/edeef/edeefc870794569210ffbc66578e70d73cb96149" alt=""
Step 2 - Create a JMS System Module for the ConnectionFactory & UDD Queue (JMSModuleCluster)
data:image/s3,"s3://crabby-images/0b369/0b36928cfcfe4ccf4b2fb975339e5567d8a521db" alt=""
data:image/s3,"s3://crabby-images/6ef9a/6ef9a1d998cbf4b8e8cac542b7e91941b2124f28" alt=""
data:image/s3,"s3://crabby-images/8f325/8f325de12e1d7ae506ea7057f847152c02c06d7e" alt=""
Step 4 - Test with a JMS Client
--------------------------------------------------
package jmsclient;
import java.util.Hashtable;
import javax.jms.JMSException;
import javax.jms.Queue;
import javax.jms.QueueConnection;
import javax.jms.QueueConnectionFactory;
import javax.jms.QueueSender;
import javax.jms.QueueSession;
import javax.jms.TextMessage;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
public class JMSClient {
public static void main(String [] args) throws JMSException,
NamingException {
final Context ic = getInitialContext();
System.out.println("*** CONTEXT =");
final QueueConnectionFactory qcf = (QueueConnectionFactory)ic.lookup("jms/MyCF");
// Lookup should specify the queue name that is mentioned as "mappedName" in MessageDriven Bean.
final Queue destQueue = (Queue)ic.lookup("jms/MyDistQueue");
ic.close();
final QueueConnection connection = qcf.createQueueConnection();
try {
final QueueSession session = connection.createQueueSession(false, 0);
final QueueSender sender = session.createSender(destQueue);
final TextMessage msg = session.createTextMessage("Hello from Lichtenau - fans of FCN");
sender.send(msg);
} catch (Exception ex) {
ex.printStackTrace();
} finally {
connection.close();
}
}
private static Context getInitialContext() throws NamingException {
Hashtable env = new Hashtable();
// Add InitialContext property assignments here.
env.put( Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory" );
// Note that by default WebLogic server is not created with security, so credentials are not needed.
// TODO: Verify the server address and port number
env.put(Context.PROVIDER_URL, "t3://localhost:7003,localhost:7004");
env.put(Context.SECURITY_PRINCIPAL, "weblogic");
env.put(Context.SECURITY_CREDENTIALS, "welcome1");
return new InitialContext( env );
}
}
------------------------------------------------------------
You can stop any of the 2 managed servers and re-test.
The Queue is alway available.