annot convert value of type [org.hornetq.jms.client.HornetQQueue] to required type [javax.jms.Destination] for property 'defaultDestination'
kittu_lal Sep 27, 2015 7:42 AMSpring + EJB + JMS
I'm trying to migrate my EJB application from JBSS 5 to WIldfly 8.
Before that i tried and succeed the same JMS queue connections in Stand-alone Application and Web Application its working fine.
When i shift to the same xml beans to to EJB , My EJB is not Connecting to queue. It is throwing Exceptiion.
Do i need to Configure anything in WIldfly-8??
Please help me .. I'm working around on this problem from 3 days but i'm not getting any solution on this...............
Exception :
Caused by: javax.ejb.EJBException: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'producerTemplate' defined in class path resource [com/pro/config/beanss.xml]: Initialization of bean failed; nested exception is org.springframework.beans.ConversionNotSupportedException: Failed to convert property value of type 'org.hornetq.jms.client.HornetQQueue' to required type 'javax.jms.Destination' for property 'defaultDestination'; nested exception is java.lang.IllegalStateException: Cannot convert value of type [org.hornetq.jms.client.HornetQQueue] to required type [javax.jms.Destination] for property 'defaultDestination': no matching editors or conversion strategy found
at org.jboss.as.ejb3.tx.CMTTxInterceptor.handleExceptionInOurTx(CMTTxInterceptor.java:187)
at org.jboss.as.ejb3.tx.CMTTxInterceptor.invokeInOurTx(CMTTxInterceptor.java:277)
at org.jboss.as.ejb3.tx.CMTTxInterceptor.requiresNew(CMTTxInterceptor.java:344)
at org.jboss.as.ejb3.tx.LifecycleCMTTxInterceptor.processInvocation(LifecycleCMTTxInterceptor.java:66)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.weld.injection.WeldInjectionContextInterceptor.processInvocation(WeldInjectionContextInterceptor.java:43)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.ejb3.component.interceptors.CurrentInvocationContextInterceptor.processInvocation(CurrentInvocationContextInterceptor.java:41)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.ee.concurrent.ConcurrentContextInterceptor.processInvocation(ConcurrentContextInterceptor.java:45)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.invocation.ContextClassLoaderInterceptor.processInvocation(ContextClassLoaderInterceptor.java:64)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.invocation.InterceptorContext.run(InterceptorContext.java:356)
at org.jboss.invocation.PrivilegedWithCombinerInterceptor.processInvocation(PrivilegedWithCombinerInterceptor.java:80)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.invocation.ChainedInterceptor.processInvocation(ChainedInterceptor.java:61)
at org.jboss.as.ee.component.BasicComponent.constructComponentInstance(BasicComponent.java:161)
... 48 more
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'producerTemplate' defined in class path resource [com/pro/config/beanss.xml]: Initialization of bean failed; nested exception is org.springframework.beans.ConversionNotSupportedException: Failed to convert property value of type 'org.hornetq.jms.client.HornetQQueue' to required type 'javax.jms.Destination' for property 'defaultDestination'; nested exception is java.lang.IllegalStateException: Cannot convert value of type [org.hornetq.jms.client.HornetQQueue] to required type [javax.jms.Destination] for property 'defaultDestination': no matching editors or conversion strategy found
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:547)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:476)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:303)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:299)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:194)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:755)
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:757)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:480)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:83)
at com.ejb.spring.jms.singleton.ApplicationContextSingleton.getBeanName(ApplicationContextSingleton.java:19)
at com.pro.session.bean.ActiveMqEJB.setSessionContext(ActiveMqEJB.java:27)
at org.jboss.as.ejb3.component.session.SessionBeanSetSessionContextMethodInvocationInterceptor.processInvocation(SessionBeanSetSessionContextMethodInvocationInterceptor.java:52)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.ee.component.AroundConstructInterceptorFactory$1.processInvocation(AroundConstructInterceptorFactory.java:28)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.weld.injection.WeldInterceptorInjectionInterceptor.processInvocation(WeldInterceptorInjectionInterceptor.java:56)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.weld.ejb.Jsr299BindingsCreateInterceptor.processInvocation(Jsr299BindingsCreateInterceptor.java:100)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.ee.component.NamespaceContextInterceptor.processInvocation(NamespaceContextInterceptor.java:50)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.ejb3.tx.CMTTxInterceptor.invokeInOurTx(CMTTxInterceptor.java:275)
... 64 more
Caused by: org.springframework.beans.ConversionNotSupportedException: Failed to convert property value of type 'org.hornetq.jms.client.HornetQQueue' to required type 'javax.jms.Destination' for property 'defaultDestination'; nested exception is java.lang.IllegalStateException: Cannot convert value of type [org.hornetq.jms.client.HornetQQueue] to required type [javax.jms.Destination] for property 'defaultDestination': no matching editors or conversion strategy found
at org.springframework.beans.BeanWrapperImpl.convertIfNecessary(BeanWrapperImpl.java:476)
at org.springframework.beans.BeanWrapperImpl.convertForProperty(BeanWrapperImpl.java:512)
at org.springframework.beans.BeanWrapperImpl.convertForProperty(BeanWrapperImpl.java:506)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.convertForProperty(AbstractAutowireCapableBeanFactory.java:1523)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1482)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1222)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:537)
... 87 more
Caused by: java.lang.IllegalStateException: Cannot convert value of type [org.hornetq.jms.client.HornetQQueue] to required type [javax.jms.Destination] for property 'defaultDestination': no matching editors or conversion strategy found
at org.springframework.beans.TypeConverterDelegate.convertIfNecessary(TypeConverterDelegate.java:287)
at org.springframework.beans.BeanWrapperImpl.convertIfNecessary(BeanWrapperImpl.java:461)
... 93 more
My xml Conf
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean name="jndiTemplateRef" class="org.springframework.jndi.JndiTemplate">
<property name="environment">
<props>
<!--<prop key="java.naming.factory.initial">org.jnp.interfaces.NamingContextFactory</prop>
<prop key="java.naming.provider.url">jnp://192.168.1.24:1099</prop>-->
<prop key="java.naming.factory.initial">org.jboss.naming.remote.client.InitialContextFactory</prop>
<prop key="java.naming.provider.url">http-remoting://localhost:8080</prop>
<!--<prop key="java.naming.factory.url.pkgs">org.jboss.ejb.client.naming</prop>-->
<prop key="jboss.naming.client.ejb.context">true</prop>
<prop key="java.naming.security.principal">prohemns</prop>
<prop key="java.naming.security.credentials">pro1234$</prop>
</props>
</property>
</bean>
<bean id="jmsConnectionFactory" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiTemplate" ref="jndiTemplateRef"/>
<property name="jndiName" value="jms/RemoteConnectionFactory" />
<property name="lookupOnStartup" value="false"/>
<property name="proxyInterface" value="javax.jms.ConnectionFactory"/>
</bean>
<!-- Definition of the JMS queue -->
<bean id="defaultDestination" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiTemplate" ref="jndiTemplateRef"/>
<property name="jndiName" value="jms/queue/EmailsQueue"/>
</bean>
<bean id="producerTemplate" class="org.springframework.jms.core.JmsTemplate">
<property name="connectionFactory" ref="jmsConnectionFactory" />
<property name="defaultDestination" ref="defaultDestination" />
</bean>
<bean id="objEjbJmsService" class="com.pro.serviceImpl.EjbJmsServiceImpl">
<property name="objJmsTemplate" ref="producerTemplate" />
</bean>
</beans>
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
standalone-full.xml
<subsystem xmlns="urn:jboss:domain:messaging:3.0">
<hornetq-server>
<persistence-enabled>true</persistence-enabled>
<security-enabled>false</security-enabled>
<journal-file-size>102400</journal-file-size>
<journal-min-files>2</journal-min-files>
<connectors>
<netty-connector name="netty" socket-binding="messaging"/>
<netty-connector name="netty-throughput" socket-binding="messaging-throughput">
<param key="batch-delay" value="50"/>
</netty-connector>
<in-vm-connector name="in-vm" server-id="0"/>
</connectors>
<acceptors>
<netty-acceptor name="netty" socket-binding="messaging"/>
<netty-acceptor name="netty-throughput" socket-binding="messaging-throughput">
<param key="batch-delay" value="50"/>
<param key="direct-deliver" value="false"/>
</netty-acceptor>
<in-vm-acceptor name="in-vm" server-id="0"/>
</acceptors>
<security-settings>
<security-setting match="#">
<permission type="send" roles="guest"/>
<permission type="consume" roles="guest"/>
<permission type="createNonDurableQueue" roles="guest"/>
<permission type="deleteNonDurableQueue" roles="guest"/>
</security-setting>
</security-settings>
<address-settings>
<address-setting match="#">
<dead-letter-address>jms.queue.DLQ</dead-letter-address>
<expiry-address>jms.queue.ExpiryQueue</expiry-address>
<redelivery-delay>0</redelivery-delay>
<max-size-bytes>10485760</max-size-bytes>
<address-full-policy>BLOCK</address-full-policy>
<message-counter-history-day-limit>10</message-counter-history-day-limit>
</address-setting>
</address-settings>
<jms-connection-factories>
<connection-factory name="InVmConnectionFactory">
<connectors>
<connector-ref connector-name="in-vm"/>
</connectors>
<entries>
<entry name="java:/ConnectionFactory"/>
</entries>
</connection-factory>
<connection-factory name="RemoteConnectionFactory">
<connectors>
<connector-ref connector-name="netty"/>
</connectors>
<entries>
<entry name="RemoteConnectionFactory"/>
<entry name="java:jboss/exported/jms/RemoteConnectionFactory"/>
</entries>
<client-failure-check-period>2147483646</client-failure-check-period>
<connection-ttl>-1</connection-ttl>
<reconnect-attempts>-1</reconnect-attempts>
</connection-factory>
<pooled-connection-factory name="hornetq-ra">
<transaction mode="xa"/>
<connectors>
<connector-ref connector-name="in-vm"/>
</connectors>
<entries>
<entry name="java:/JmsXA"/>
<entry name="java:jboss/DefaultJMSConnectionFactory"/>
</entries>
</pooled-connection-factory>
</jms-connection-factories>
<jms-destinations>
<jms-queue name="testQueue">
<entry name="queue/test"/>
<entry name="java:jboss/exported/jms/queue/test"/>
</jms-queue>
<jms-queue name="callStatus">
<entry name="queue/callStatus"/>
<entry name="java:jboss/exported/jms/queue/callStatus"/>
</jms-queue>
<jms-queue name="onlineUsers">
<entry name="queue/onlineUsers"/>
<entry name="java:jboss/exported/jms/queue/onlineUsers"/>
</jms-queue>
<jms-queue name="dispatch">
<entry name="queue/dispatch"/>
<entry name="java:jboss/exported/jms/queue/dispatch"/>
</jms-queue>
<jms-queue name="faileddispatches">
<entry name="queue/faileddispatches"/>
<entry name="java:jboss/exported/jms/queue/faileddispatches"/>
</jms-queue>
<jms-queue name="vehicleStatus">
<entry name="queue/vehicleStatus"/>
<entry name="java:jboss/exported/jms/queue/vehicleStatus"/>
</jms-queue>
<jms-queue name="complaintStatus">
<entry name="queue/complaintStatus"/>
<entry name="java:jboss/exported/jms/queue/complaintStatus"/>
</jms-queue>
<jms-queue name="fieldUpdateStatus">
<entry name="queue/fieldUpdateStatus"/>
<entry name="java:jboss/exported/jms/queue/fieldUpdateStatus"/>
</jms-queue>
<jms-queue name="StatisticsQueue">
<entry name="queue/StatisticsQueue"/>
<entry name="java:jboss/exported/jms/queue/StatisticsQueue"/>
</jms-queue>
<jms-queue name="EmailsQueue">
<entry name="queue/EmailsQueue"/>
<entry name="java:jboss/exported/jms/queue/EmailsQueue"/>
</jms-queue>
<jms-topic name="testTopic">
<entry name="topic/test"/>
<entry name="java:jboss/exported/jms/topic/test"/>
</jms-topic>
</jms-destinations>
</hornetq-server>
</subsystem>
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Class Loaders Are as Follows
<?xml version="1.0" encoding="UTF-8"?>
<module xmlns="urn:jboss:module:1.0" name="org.spring4x" slot="4.0.1 RELEASE">
<resources>
<resource-root path="aopalliance-1.0.jar"/>
<resource-root path="aspectjtools-1.7.4.jar"/>
<resource-root path="aspectjweaver-1.8.4.jar"/>
<resource-root path="org-apache-commons-logging.jar"/>
<resource-root path="spring-aop-4.1.7.RELEASE.jar"/>
<resource-root path="spring-aspects-4.1.7.RELEASE.jar"/>
<resource-root path="spring-beans-4.1.7.RELEASE.jar"/>
<resource-root path="spring-context-4.1.7.RELEASE.jar"/>
<resource-root path="spring-context-support-4.1.7.RELEASE.jar"/>
<resource-root path="spring-core-4.1.7.RELEASE.jar"/>
<resource-root path="spring-expression-4.1.7.RELEASE.jar"/>
<resource-root path="spring-instrument-4.1.7.RELEASE.jar"/>
<resource-root path="spring-instrument-tomcat-4.1.7.RELEASE.jar"/>
<resource-root path="spring-jdbc-4.1.7.RELEASE.jar"/>
<resource-root path="spring-jms-4.1.7.RELEASE.jar"/>
<resource-root path="spring-messaging-4.1.7.RELEASE.jar"/>
<resource-root path="spring-orm-4.1.7.RELEASE.jar"/>
<resource-root path="spring-oxm-4.1.7.RELEASE.jar"/>
<resource-root path="spring-test-4.1.7.RELEASE.jar"/>
<resource-root path="spring-tx-4.1.7.RELEASE.jar"/>
<resource-root path="spring-web-4.1.7.RELEASE.jar"/>
<resource-root path="spring-webmvc-4.1.7.RELEASE.jar"/>
<resource-root path="jboss-client.jar"/> |
</resources>
<dependencies>
<module name="javax.api"/>
<module name="javaee.api"/>
<module name="org.apache.commons.logging"/>
<module name="org.hibernate" slot="main"/>
<module name="org.dom4j" slot="main"/>
<module name="org.jboss.vfs"/>
<module name="javax.el.api" export="true"/>
<module name="com.sun.xml.bind" export="true"/>
</dependencies>
</module>
Please any one can suggest the solution............