Связывание JNDI в JBoss (LiveCycle под ключ)

Я использую готовый проект Adobe LiveCycle ES 2, работающий на JBoss AS 4.2.1.GA. У меня проблема с тем, чтобы привязка JNDI работала в JBoss. Это кажется пугающе похожим на предыдущий пост, проблема настройки JBoss для работы с JNDI, но я точно не нашел решения.

Это моя установка. У меня есть файл -ds.xml:

C:\Adobe\Adobe LiveCycle ES2\jboss\server\lc_turnkey\deploy\rmb-ds.xml

Содержимое этого файла выглядит следующим образом:

<datasources>
   <local-tx-datasource>
      <jndi-name>RMB_DS</jndi-name>
      <connection-url>jdbc:sqlserver://localhost\SQLEXPRESS;DatabaseName=rmb</connection-url>
      <driver-class>com.microsoft.sqlserver.jdbc.SQLServerDriver</driver-class>
      <user-name>sa</user-name>
      <password>password</password>
      <check-valid-connection-sql>SELECT 1 FROM sysobjects</check-valid-connection-sql>
      <!-- corresponding type-mapping in the standardjbosscmp-jdbc.xml (optional) -->
      <metadata>
         <type-mapping>MS SQLSERVER2000</type-mapping>
      </metadata>
   </local-tx-datasource>
</datasources>

У меня есть проект Java, чей /RMB/WebContent/WEB-INF/web.xml содержит следующее:

<resource-ref>
    <description>DB Connection</description>
    <res-ref-name>java:RMB_DS</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <res-auth>Container</res-auth>
</resource-ref>

Теперь каждый раз, когда я развертываю WAR, происходит сбой со следующей ошибкой:

2011-09-06 15:44:17,786 ERROR [org.jboss.deployment.MainDeployer] Could not start deployment: file:/C:/Adobe/Adobe LiveCycle ES2/jboss/server/lc_turnkey/deploy/RMB.war
org.jboss.deployment.DeploymentException: Error during deploy; - nested throwable: (javax.naming.NamingException: resource-ref: java:RMB_DS has no valid JNDI binding. Check the jboss-web/resource-ref.)
    at org.jboss.web.AbstractWebDeployer.start(AbstractWebDeployer.java:384)
...
Caused by: javax.naming.NamingException: resource-ref: java:RMB_DS has no valid JNDI binding. Check the jboss-web/resource-ref.
    at org.jboss.web.AbstractWebDeployer.linkResourceRefs(AbstractWebDeployer.java:623)

Я на 100% уверен, что сама привязка JNDI верна. Я вижу следующее в веб-консоли> System> JMX Beans> jboss.jdbc> jboss.jdbc: service = metadata, datasource = RMB_DS

MBean Name: Domain Name:    jboss.jdbc
service:    metadata
datasource: RMB_DS
MBean Java Class:   org.jboss.ejb.plugins.cmp.jdbc.metadata.DataSourceMetaData

Кроме того, с помощью LiveCycle workbench я могу создать процесс, который обращается к этой службе и запускает некоторый SQL для источника данных java: / RMB_DS ..

Итак, что-то не так с моей WAR или web.xml, верно? Я упускаю что-то очевидное?


person Robert Mark Bram    schedule 06.09.2011    source источник


Ответы (1)


Спасибо Кетану, она классная!

Нужен jboss-web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<jboss-web>
    <resource-ref>
        <res-ref-name>RMB_DS</res-ref-name>
        <jndi-name>java:/RMB_DS</jndi-name>
    </resource-ref>
</jboss-web>

И изменил исходный web.xml, чтобы он имел:

<resource-ref>
   <description>DB Connection</description>
   <res-ref-name>RMB_DS</res-ref-name>
   <res-type>javax.sql.DataSource</res-type>
   <res-auth>Container</res-auth>
</resource-ref>

Что соответствует rmb-ds.xml

<datasources>
   <local-tx-datasource>
      <jndi-name>RMB_DS</jndi-name>
      <connection-url>jdbc:sqlserver://localhost\SQLEXPRESS;DatabaseName=RMB</connection-url>
      <driver-class>com.microsoft.sqlserver.jdbc.SQLServerDriver</driver-class>
      <user-name>sa</user-name>
      <password>password</password>
      <check-valid-connection-sql>SELECT 1 FROM sysobjects</check-valid-connection-sql>
      <!-- corresponding type-mapping in the standardjbosscmp-jdbc.xml (optional) -->
      <metadata>
         <type-mapping>MS SQLSERVER2000</type-mapping>
      </metadata>
   </local-tx-datasource>
</datasources>
person Robert Mark Bram    schedule 07.09.2011