Diferencia entre revisiones de «JMS Con GlassFish»

De Dos Ideas.
Saltar a: navegación, buscar
Línea 11: Línea 11:
 
directorio-de-glassfish/lib/appserv-admin.jar
 
directorio-de-glassfish/lib/appserv-admin.jar
 
</code>
 
</code>
 +
 +
==Enviar un mensaje==
 +
Para enviar un mensaje desde un cliente remoto, es necesario incluir los JAR de GlassFiss antes mencionados, y configurar el ''Context'' con las variables correspondientes.
 +
 +
<code java>
 +
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();
 +
}
 +
 +
</code>
 +
  
 
==Ver también==
 
==Ver también==
 
[https://glassfish.dev.java.net/nonav/javaee5/docs/DG/beakt.html#beali Documentación de GlassFish]
 
[https://glassfish.dev.java.net/nonav/javaee5/docs/DG/beakt.html#beali Documentación de GlassFish]

Revisión del 16:05 31 mar 2009

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/j2ee.jar directorio-de-glassfish/lib/install/aplications/jmsra/imqjmsra.jar

Encontré también necesario incluir

directorio-de-glassfish/lib/appserv-admin.jar

Enviar un mensaje

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

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