Just an FYI - the website is a wiki underneath. Click "Edit Page" on the
right and you should be able to add your own information to the JMS page.

Regards,
- Dan

On 12/1/06, Ruth, Brice D <[EMAIL PROTECTED]> wrote:

 Very nice. Good to know. It'd be good to pull this info together &
publish it out somewhere (got a blog?) - I imagine it would be useful to
others!

Nice way to get 2-phase commit w/ a service if you can't do WS-AT yet.

-Brice

 -----Original Message-----
*From:* Wayne Keenan [mailto:[EMAIL PROTECTED]
*Sent:* Friday, December 01, 2006 10:17 AM
*To:* [email protected]
*Subject:* Re: [xfire-user] Set JMSChannel replyTo

Sorry, that;s misleasding debug, as the reply-to isnt in the message
context.
Stopping the server and inspecting the message on the queue shows that the
JMS (cough, MQ) reply-to variable is set correctly.


On 01/12/06, Ruth, Brice D <[EMAIL PROTECTED]> wrote:
>
>  Hmm, odd. The DEBUG logs seem to indicate that the reply-to still isn't
> being set ... good that its working, though! :)
>
> 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> msgctx.getProp(REPLY_TO):null
>
>  -----Original Message-----
> *From:* Wayne Keenan [mailto:[EMAIL PROTECTED]
> *Sent:* Friday, December 01, 2006 3:36 AM
> *To:* [email protected]
> *Subject:* Re: [xfire-user] Set JMSChannel replyTo
>
> This works fine now.  I had some (duplicate) server side test code
> messing things up on the service registry side.
>
> On 30/11/06, Wayne Keenan < [EMAIL PROTECTED]> wrote:
> >
> > It works, and I  have discovered that this line in the client:
> >
> >         ((XFireProxy) Proxy.getInvocationHandler
> > (echo)).getClient().setEndpointUri("jms://ARSYSTEM_OUTBOUND");
> >
> > sets the replyto queue.  (see server log below)
> >
> > I have added my own additional logging and have also created and
> > additional JMS sessions (1 'in', 1 'out') in JMSChannel to get around the MQ
> > asych error, I dont think this is a 'proper all encompasing fix', it just
> > solves my needs at the moment.
> >
> > But, my problem at the moment is that the Service (in this case Echo)
> > does not seem to come accross:
> >
> > client log:
> > 719  [main] DEBUG org.codehaus.xfire.client.XFireProxy  - Method
> > [echo] [hello]
> > 719  [main] DEBUG org.codehaus.xfire.transport.jms.JMSTransport  -
> > Creating new channel for uri: jms://ARSYSTEM_OUTBOUND
> > 735  [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > DestName :ARSYSTEM_OUTBOUND
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> > adding handler [EMAIL PROTECTED] to
> > phase send
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - adding
> > handler [EMAIL PROTECTED] phase transport
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  - adding
> > handler [EMAIL PROTECTED] phase post-invoke
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> > Invoking phase post-invoke
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking handler org.codehaus.xfire.soap.handler.SoapSerializerHandlerin 
phase post-invoke
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> > Invoking phase policy
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking phase user
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking phase transport
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking handler org.codehaus.xfire.soap.handler.SoapActionOutHandlerin 
phase transport
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking phase send
> > 1094 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > Invoking handler org.codehaus.xfire.handler.OutMessageSender in phase
> > send
> > 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > ResponseURI:jms://ARSYSTEM_INBOUND?Echo
> > 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > msgtxt:<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/";
> > xmlns:xsd=" http://www.w3.org/2001/XMLSchema " 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance";><soap:Body><echo
> > xmlns=" 
http://test.xfire.codehaus.org";><in0>hello</in0></echo></soap:Body></soap:Envelope>
> >
> > 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel   -
> > corrid:11649244730150-704411791
> > 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > msgctx.getProp(REPLY_TO):null
> > 1219 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > selector=
> > 1250 [main] INFO  org.codehaus.xfire.transport.jms.JMSChannel  - Sent
> > message: Source ID: 65B4422E-55DF-C388-8ABA-6D2E56F491E3 Destination: null
> > JMSType: null
> > 11407 [main] DEBUG org.codehaus.xfire.client.XFireProxy  - Result
> > [null]
> > response:null
> >
> >
> >
> >
> >
> > server log:
> >
> >
> > 30/11/2006 22:07:53,171 DEBUG asyncDelivery2 JMSChannel.onMessage - recv 
msg=<soap:Envelope xmlns:soap="
> >
> > http://schemas.xmlsoap.org/soap/envelope/
> > " xmlns:xsd="http://www.w3.org/2001/XMLSchema
> >
> > " xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance
> > "><soap:Body><echo xmlns="
> >
> > 
http://test.xfire.codehaus.org";><in0>hello</in0></echo></soap:Body></soap:Envelope>
> >
> >
> >
> > 30/11/2006 22:07:53,171 DEBUG asyncDelivery2 JMSChannel.onMessage - dest 
name=ARSYSTEM_INBOUND
> > 30/11/2006 22:07:53,171 DEBUG asyncDelivery2 JMSChannel.onMessage - 
reply-to=queue:///ARSYSTEM_OUTBOUND
> > 30/11/2006 22:07:53,171 DEBUG asyncDelivery2
> >
> >
> > DefaultEndpoint.onReceive - Received message to jms://ARSYSTEM_INBOUND
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.addHandler - 
adding handler [EMAIL PROTECTED]
> >
> >  to phase dispatch
> >
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.addHandler - 
adding handler [EMAIL PROTECTED] to phase parse
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> >
> > HandlerPipeline.addHandler
> >  - adding handler [EMAIL PROTECTED] to phase pre-invoke
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.addHandler - 
adding handler
> >
> > [EMAIL PROTECTED]
> >  to phase dispatch
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.addHandler - 
adding handler [EMAIL PROTECTED]
> >
> >  to phase dispatch
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> > HandlerPipeline.addHandler - adding handler [EMAIL PROTECTED] to phase 
dispatch
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> >
> > HandlerPipeline.invoke - Invoking phase transport
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> > HandlerPipeline.invoke - Invoking phase parse
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.invoke
> >  - Invoking handler
> > org.codehaus.xfire.soap.handler.ReadHeadersHandler in phase parse
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> > HandlerPipeline.invoke - Invoking phase pre-dispatch
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2
> > HandlerPipeline.invoke
> >  - Invoking phase dispatch
> > 30/11/2006 22:07:53,187 DEBUG asyncDelivery2 HandlerPipeline.invoke - 
Invoking handler
> > org.codehaus.xfire.handler.LocateBindingHandler in phase dispatch
> > 30/11/2006 22:07:53,187 INFO asyncDelivery2
> >
> > DefaultFaultHandler.invoke - Fault occurred!
> > org.codehaus.xfire.fault.XFireFault: Could not find a service to invoke.
> >
> >
> >       at 
org.codehaus.xfire.handler.LocateBindingHandler.invoke(LocateBindingHandler.java:39)
> >
> >
> >
> >
> >
> >
> >
> > On 30/11/06, Ruth, Brice D < [EMAIL PROTECTED]> wrote:
> > >
> > >  Wow, I had no idea you could use the XFire client for JMS. That's
> > > pretty cool (if it works).
> > >
> > > Um ... the problem here seems to be that you're not setting the
> > > ReplyTo. That may be what MQ is balking on as well. Hmmm.
> > >
> > > It looks like JMSChannel.java in XFire sets the JMSReplyTo from a
> > > javax.jms.Destination (say, a Queue) that is stored in the
> > > MessageContext under the key "REPLY_TO". Look here:
> > >
> > >
> > > 
http://svn.xfire.codehaus.org/browse/xfire/trunk/xfire/xfire-jms/src/main/org/codehaus/xfire/transport/jms/JMSChannel.java?r=trunk
> > >
> > > At approx. lines 194,205.
> > >
> > > It looks like the XFire client (org.codehaus.xfire.client.Client)
> > > extends org.codehaus.xfire.AbstractContext, so just calling:
> > >
> > > getClient().setProperty("REPLY_TO", <destination>)
> > >
> > > might work. I don't have a working MQ setup at the moment, otherwise
> > > I'd try.
> > >
> > > Cheers,
> > > Brice
> > >
> > >  -----Original Message-----
> > > *From:* Wayne Keenan [mailto:[EMAIL PROTECTED]
> > > *Sent:* Thursday, November 30, 2006 2:39 PM
> > > *To:* [email protected]
> > > *Subject:* Re: [xfire-user] Set JMSChannel replyTo
> > >
> > > Thanks for the response.  I think I need to set ws addressing on the
> > > dynamic client, but Im a unsure how.
> > > I am registering the JMS transport before creating the dynamic
> > > client, below are the logs.  perhaps what im trying
> > > is completely wrong w/ dynamic client as im getting a MQ error:
> > > Caused by: javax.jms.JMSException: MQJMS1013: operation invalid
> > > whilst session is using asynchronous delivery
> > >
> > > my test client is:
> > >
> > >
> > >
> > > import java.lang.reflect.Proxy;
> > > import java.net.MalformedURLException;
> > > import java.net.URL;
> > >
> > > import javax.jms.QueueConnectionFactory;
> > >
> > > import org.codehaus.xfire.DefaultXFire;
> > > import org.codehaus.xfire.XFire ;
> > > import org.codehaus.xfire.client.Client;
> > > import org.codehaus.xfire.client.XFireProxy;
> > > import org.codehaus.xfire.client.XFireProxyFactory;
> > > import org.codehaus.xfire.service.Service;
> > > import org.codehaus.xfire.service.binding.ObjectServiceFactory ;
> > >
> > > import org.codehaus.xfire.test.Echo;
> > > import org.codehaus.xfire.transport.jms.JMSTransport;
> > >
> > > import com.ibm.mq.jms.JMSC;
> > > import com.ibm.mq.jms.MQQueueConnectionFactory;
> > >
> > >
> > > public class JMSWSEchoTest {
> > >
> > >     private XFire xfire;
> > >     private QueueConnectionFactory factory;
> > >     private JMSTransport transport;
> > >
> > >
> > >     public void setUp()
> > >         throws Exception
> > >     {
> > >         factory = new MQQueueConnectionFactory();
> > >         ((MQQueueConnectionFactory)factory).setTransportType(
> > > JMSC.MQJMS_TP_BINDINGS_MQ);
> > >
> > > ((MQQueueConnectionFactory)factory).setHostName("localhost");
> > >
> > > ((MQQueueConnectionFactory)factory).setQueueManager("QM_server");
> > >         ((MQQueueConnectionFactory)factory).setPort(1414);
> > >
> > >         xfire = new DefaultXFire();
> > >         transport = (JMSTransport) new JMSTransport(xfire,
> > > factory);
> > >         xfire.getTransportManager ().register(transport);
> > >     }
> > >
> > >     public void testClient1() throws Exception {
> > >
> > >
> > >         // Create a ServiceFactory to create the ServiceModel.
> > >         // We need to add the JMSTransport to the list of bindings
> > > to create.
> > >         ObjectServiceFactory sf = new ObjectServiceFactory(
> > > xfire.getTransportManager());
> > >         sf.addSoap11Transport(JMSTransport.BINDING_ID);
> > >
> > >         // Create the service model
> > >         Service serviceModel = sf.create(Echo.class);
> > >
> > >         // Create a proxy for the service
> > >         XFireProxyFactory factory = new XFireProxyFactory(xfire);
> > >         Echo echo = (Echo) factory.create(serviceModel,
> > > "jms://ARSYSTEM_OUTBOUND");
> > >
> > >         // Since JMS doesn't really have a concept of anonymous
> > > endpoints, we
> > >         // need
> > >         // need to let xfire know what JMS endpoint we should use
> > >         ((XFireProxy) 
Proxy.getInvocationHandler(echo)).getClient().setEndpointUri("jms://ARSYSTEM_INBOUND");
> > >
> > >         // run the client!
> > >         String resString = echo.echo("hello");
> > >         //assertEquals("hello", resString);
> > >         System.out.println("response:" + resString);
> > >     }
> > >     public void testClient2() throws MalformedURLException,
> > > Exception
> > >     {
> > >         Client client = new Client(new 
URL("http://localhost:8191/Echo?wsdl
> > > "));
> > >         Object[] response = client.invoke("echo", new Object[]
> > > {"hello"});
> > >         System.out.println((String) response[0]);
> > >
> > >     }
> > >      public static void main(String args[]) throws Exception
> > >         {
> > >
> > >             try
> > >             {
> > >                 JMSWSEchoTest jwt = new JMSWSEchoTest();
> > >
> > >                 jwt.setUp();
> > >                 jwt.testClient1();
> > >
> > >             }
> > >             catch (/*MalformedURL*/Exception e)
> > >             {
> > >                 e.printStackTrace();
> > >             }
> > >         }
> > >
> > >
> > > }
> > >
> > >
> > >
> > >
> > > 0    [main] DEBUG
> > > org.codehaus.xfire.transport.DefaultTransportManager   - Registered
> > > transport [EMAIL PROTECTED]
> > > 0    [main] DEBUG
> > > org.codehaus.xfire.transport.DefaultTransportManager  - Registered
> > > transport
> > > [EMAIL PROTECTED]
> > > 15   [main] DEBUG
> > > org.codehaus.xfire.transport.DefaultTransportManager  - Registered
> > > transport
> > > [EMAIL PROTECTED]
> > > 15   [main] DEBUG
> > > org.codehaus.xfire.transport.DefaultTransportManager   - Registered
> > > transport [EMAIL PROTECTED]
> > > 15   [main] DEBUG
> > > org.codehaus.xfire.transport.DefaultTransportManager  - Registered
> > > transport [EMAIL PROTECTED]
> > > 1422 [main] DEBUG
> > > org.codehaus.xfire.transport.DefaultTransportManager  - Registered
> > > transport [EMAIL PROTECTED]
> > > 1422 [main] DEBUG
> > > org.codehaus.xfire.transport.DefaultTransportManager   - Registered
> > > transport
> > > [EMAIL PROTECTED]
> > > 1422 [main] DEBUG
> > > org.codehaus.xfire.transport.DefaultTransportManager  - Registered
> > > transport [EMAIL PROTECTED]
> > > 1422 [main] DEBUG
> > > org.codehaus.xfire.transport.DefaultTransportManager  - Registered
> > > transport [EMAIL PROTECTED]
> > > 2734 [main] DEBUG org.codehaus.xfire.client.XFireProxy  - Method
> > > [echo] [hello]
> > > 2734 [main] DEBUG org.codehaus.xfire.transport.jms.JMSTransport  -
> > > Creating new channel for uri: jms://ARSYSTEM_INBOUND
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > > adding handler [EMAIL PROTECTED] phase send
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > > adding handler
> > > [EMAIL PROTECTED] to phase
> > > transport
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> > > adding handler
> > > [EMAIL PROTECTED] to
> > > phase post-invoke
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > > Invoking phase post-invoke
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> > > Invoking handler
> > > org.codehaus.xfire.soap.handler.SoapSerializerHandler in phase
> > > post-invoke
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > > Invoking phase policy
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline   -
> > > Invoking phase user
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > > Invoking phase transport
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > > Invoking handler
> > > org.codehaus.xfire.soap.handler.SoapActionOutHandler in phase
> > > transport
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > > Invoking phase send
> > > 3875 [main] DEBUG org.codehaus.xfire.handler.HandlerPipeline  -
> > > Invoking handler org.codehaus.xfire.handler.OutMessageSender in
> > > phase send
> > > 4172 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > > ResponseURI:jms://ARSYSTEM_OUTBOUND
> > > 4172 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > > msgtxt:<soap:Envelope xmlns:soap="
> > > http://schemas.xmlsoap.org/soap/envelope/"; 
xmlns:xsd="http://www.w3.org/2001/XMLSchema";
> > > xmlns:xsi=" http://www.w3.org/2001/XMLSchema-instance "><soap:Body><echo
> > > 
xmlns="http://test.xfire.codehaus.org";><in0>hello</in0></echo></soap:Body></soap:Envelope>
> > >
> > > 4172 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > > corrid:11649131364370-593738066
> > > 4172 [main] DEBUG org.codehaus.xfire.transport.jms.JMSChannel  -
> > > msgctx.getProp(REPLY_TO):null
> > > org.codehaus.xfire.XFireRuntimeException : Could not invoke
> > > service.. Nested exception is org.codehaus.xfire.fault.XFireFault:
> > > Error sending message
> > > org.codehaus.xfire.fault.XFireFault: Error sending message
> > >     at org.codehaus.xfire.transport.jms.JMSChannel.send (
> > > JMSChannel.java:246)
> > >     at org.codehaus.xfire.handler.OutMessageSender.invoke(
> > > OutMessageSender.java:26)
> > >     at org.codehaus.xfire.handler.HandlerPipeline.invoke(
> > > HandlerPipeline.java:131)
> > >     at org.codehaus.xfire.client.Invocation.invoke (Invocation.java
> > > :75)
> > >     at org.codehaus.xfire.client.Client.invoke(Client.java:335)
> > >     at org.codehaus.xfire.client.XFireProxy.handleRequest(
> > > XFireProxy.java:77)
> > >     at org.codehaus.xfire.client.XFireProxy.invoke (XFireProxy.java
> > > :57)
> > >     at $Proxy0.echo(Unknown Source)
> > >     at
> > > com.turingsmi.messagelogic.net.tests.JMSWSEchoTest.testClient1(
> > > JMSWSEchoTest.java:66)
> > >     at com.turingsmi.messagelogic.net.tests.JMSWSEchoTest.main (
> > > JMSWSEchoTest.java:85)
> > > Caused by: javax.jms.JMSException: MQJMS1013: operation invalid
> > > whilst session is using asynchronous delivery
> > >     at com.ibm.mq.jms.services.ConfigEnvironment.newException(
> > > ConfigEnvironment.java :567)
> > >     at com.ibm.mq.jms.MQMessageProducer.send(MQMessageProducer.java
> > > :1193)
> > >     at com.ibm.mq.jms.MQMessageProducer.send(MQMessageProducer.java
> > > :3123)
> > >     at org.codehaus.xfire.transport.jms.JMSChannel.send(
> > > JMSChannel.java :238)
> > >     ... 9 more
> > >
> > >
> > > On 30/11/06, Ruth, Brice D <[EMAIL PROTECTED]> wrote:
> > > >
> > > >  I'm not sure what you mean w/ dynamic client ... I don't think
> > > > the dynamic client understands JMS, does it? Maybe it does and I've 
missed
> > > > something. When we've setup JMS with XFire in an MQ Series environment, 
the
> > > > MQ client application set the ReplyTo in the API calls to the MQ jars - 
so
> > > > its specified in the JMS message. XFire just picks it up from there and 
does
> > > > the right thing. You don't need to specify the reply-to on the server 
side,
> > > > if memory serves.
> > > >
> > > > Cheers,
> > > > Brice
> > > >
> > > >  -----Original Message-----
> > > > *From:* Wayne Keenan [mailto:[EMAIL PROTECTED]
> > > > *Sent:* Thursday, November 30, 2006 12:15 PM
> > > > *To:* [email protected]
> > > > *Subject: *[xfire-user] Set JMSChannel replyTo
> > > >
> > > > Hi,
> > > >
> > > > Please can someone advise me on how I set the JMS ReplyTo property
> > > > on the serverside service.xml and also for a 'DynamicClient'?
> > > >
> > > > Thanks
> > > > Wayne
> > > >
> > >
> > >
> >
>



--
Dan Diephouse
Envoi Solutions
http://envoisolutions.com | http://netzooid.com/blog

Reply via email to