JMS Con GlassFish

De Dos Ideas.
Saltar a: navegación, buscar

Para utilizar JMS con GlassFish es necesario incluir en el classpath del cliente los siguientes Jars que pueden encontrarse en el directorio de instalación de GlassFish: directorio-de-glassfish/lib/appserv-rt.jar directorio-de-glassfish/lib/appserv-admin.jar directorio-de-glassfish/lib/j2ee.jar directorio-de-glassfish/lib/install/aplications/jmsra/imqjmsra.jar

Enviar un mensaje

Para enviar un mensaje desde un cliente remoto, es necesario incluir los JAR de GlassFish antes mencionados, y configurar el Context con las variables correspondientes.

El siguiente ejemplo se conecta a un GlassFish en el equipo "localhost", en el cual está configurado un QueueConnectionFactory bajo el nombre JNDI "jms/holaMundoConnectionFactory" y una Queue bajo el nombre JNDI "jms/holaMundoQueue".

Properties props = new Properties(); props.setProperty("java.naming.factory.initial",

     "com.sun.enterprise.naming.SerialInitContextFactory");

props.setProperty("java.naming.factory.url.pkgs",

     "com.sun.enterprise.naming");

props.setProperty("java.naming.factory.state",

     "com.sun.corba.ee.impl.presentation.rmi.JNDIStateFactoryImpl");

props.setProperty("java.naming.provider.url",

     "localhost");

Context jndiContext = new InitialContext(props);

QueueConnectionFactory queueConnectionFactory = (QueueConnectionFactory)

     jndiContext.lookup("jms/holaMundoConnectionFactory");

Queue queue = (Queue) jndiContext.lookup("jms/holaMundoQueue"); QueueConnection queueCon = null;

try {

   queueCon = queueConnectionFactory.createQueueConnection();
   QueueSession session = queueCon.createQueueSession(false, Session.AUTO_ACKNOWLEDGE);
   QueueSender sender = session.createSender(queue);
   TextMessage message = session.createTextMessage();
   message.setText("Hola, mundo");
   sender.send(message);

} finally {

   if (queueCon != null) {
   queueCon.close();

}

Ver también

Documentación de GlassFish