Javaは、Oracle AQからのメッセージをデキューできません
-
13-12-2019 - |
質問
Spring DefaultMessageListeneNContainerに基づくアプリケーションをWebLogicに展開しようとしています。外部サーバーを使用してWebLogicを設定して、JNDI名の下のAQ接続ファクトリと宛先へのアクセスを提供しました。
私はそれが受け取るメッセージを記録する単純なメッセージリスナーを持っています(ただのテスト)、以下のSpring DMLCでこのメッセージリスナーを包みます。
<jee:jndi-lookup id="connectionFactory" jndi-name="jms/aq/admAQCF" />
<jee:jndi-lookup id="handlersDest" jndi-name="jms/aq/dpqueue"/>
<beans:bean id="testMessageListener" class="aquila.administrator.docprod.core.handler.adm.TestHandler"/>
<beans:bean id="testMLC" class="org.springframework.jms.listener.DefaultMessageListenerContainer">
<beans:property name="connectionFactory" ref="connectionFactory"/>
<beans:property name="destination" ref="handlersDest"/>
<beans:property name="messageListener" ref="testMessageListener"/>
</beans:bean>
.
このアプリケーションをWebLogicにデプロイするたびに、DMLCから次の例外が表示されます。
testMLC-26 [Tue Mar 13 14:07:52 GMT 2012] AQjmsConsumer.jdbcDequeue: Exception: oracle.jms.AQjmsException: JMS-122: Internal error Corrupted message
oracle.jms.AQjmsException: JMS-122: Internal error Corrupted message
at oracle.jms.AQjmsError.throwEx(AQjmsError.java:334)
at oracle.jms.AQjmsUtil.getTextData(AQjmsUtil.java:751)
at oracle.jms.AQjmsTextMessage.readTextMessageContainer(AQjmsTextMessage.java:308)
at oracle.jms.AQjmsTextMessage.<init>(AQjmsTextMessage.java:148)
at oracle.jms.AQjmsConsumer.jdbcDequeue(AQjmsConsumer.java:1389)
at oracle.jms.AQjmsConsumer.receiveFromAQ(AQjmsConsumer.java:1035)
at oracle.jms.AQjmsConsumer.receiveFromAQ(AQjmsConsumer.java:960)
at oracle.jms.AQjmsConsumer.receiveFromAQ(AQjmsConsumer.java:938)
at oracle.jms.AQjmsConsumer.receive(AQjmsConsumer.java:790)
at org.springframework.jms.listener.AbstractPollingMessageListenerContainer.receiveMessage(AbstractPollingMessageListenerContainer.java:431)
at org.springframework.jms.listener.AbstractPollingMessageListenerContainer.doReceiveAndExecute(AbstractPollingMessageListenerContainer.java:311)
at org.springframework.jms.listener.AbstractPollingMessageListenerContainer.receiveAndExecute(AbstractPollingMessageListenerContainer.java:264)
at org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.invokeListener(DefaultMessageListenerContainer.java:1071)
at org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.executeOngoingLoop(DefaultMessageListenerContainer.java:1063)
at org.springframework.jms.listener.DefaultMessageListenerContainer$AsyncMessageListenerInvoker.run(DefaultMessageListenerContainer.java:960)
at java.lang.Thread.run(Thread.java:662)
.
これを解決する方法は、Javaがキュー上のメッセージを受信できるように知っていますか?
ありがとう
解決
これに対する答えは、実際にメッセージキューからデキューしようとしていたもののクラスパスに "orai18n.jar"を追加することでした。マイ例では、JARをアプリケーションサーバーのクラスパスに追加し、その問題を解決しました。
所属していません StackOverflow