在部署EJB的訊息驅動Bean時遇到了如下的錯誤:
ERROR [org.jboss.resource.adapter.jms.inflow.JmsActivation] (WorkManager(2)-2) Unable to reconnect org.jboss.resource.adapter.jms.inflow.JmsActivationSpec@2705ea(ra=org.jboss.resource.adapter.jms.JmsResourceAdapter@737612 destination=queue/myqueue destinationType=javax.jms.Queue tx=true durable=false reconnect=10 provider=java:/DefaultJMSProvider user=null maxMessages=1 minSession=1 maxSession=15 keepAlive=60000 useDLQ=true DLQHandler=org.jboss.resource.adapter.jms.inflow.dlq.GenericDLQHandler DLQJndiName=queue/DLQ DLQUser=null DLQMaxResent=5)
javax.naming.NameNotFoundException: myqueue not bound
解決方案一:
在JBoss根目錄\server\default\deploy下的mail-service.xml檔案中新增以下程式碼:
<mbean code="org.jboss.mq.server.jmx.Queue" name="jboss.org.destination:server=Queue,name=myqueue" > <attribute name="JNDIName" >queue/myqueue</attribute> <depends optional-attribute-name = "DestinationManager" > jboss.mq:service=DestinationManager </depends> </mbean>
解決方案二:
在Jboss的server\default\deploy目錄中建立一個xxx-service.xml檔案,其中xxx可以任意取值,但必須跟“-service”字尾,例如,MDB-service.xml。該檔案可以放在deploy或其子目錄(可以是多層子目錄)中。該檔案的內容如下:
<?xml version="1.0" encoding="UTF-8"?> <server> <mbean code="org.jboss.mq.server.jmx.Queue" name="jboss.mq.destination:service=Queue,name=myqueue"> <depends optional-attribute-name="DestinationManager">jboss.mq:service=DestinationManager</depends> </mbean> </server>
原因:
訊息驅動Bean的註解如下:
@MessageDriven( activationConfig = { @ActivationConfigProperty(propertyName="destinationType", propertyValue="javax.jms.Queue"), @ActivationConfigProperty(propertyName="destination", propertyValue="queue/myqueue") } )
訊息驅動Bean需要使用@MessageDriven進行註解。要注意的是destination屬性的值是queue/myqueue。JBoss不會自已建立一個Queue物件,因此,需要手工來配置Queue物件。
OK,採用以上解決方案的一種即可解決此問題,只需重新部署一下我們編寫的訊息驅動Bean,然後執行客戶端,你會發現已經成功的呼叫到了我們的訊息驅動Bean。