在jetty中定义两个数据源(jetty-env.xml)

时间:2012-07-04 12:21:19

标签: java jetty datasource

我正在尝试使用jetty-env.xml文件在我的Web应用程序中定义两个数据源。 只使用一个数据源就可以正常工作,但是在添加第二个数据源时我得到了这个例外:

java.lang.IllegalStateException: Nothing to bind for name javax.sql.DataSource/default

这是我的配置:

码头-env.xml

<Configure class="org.eclipse.jetty.webapp.WebAppContext">
    <New id="ds" class="org.eclipse.jetty.plus.jndi.Resource">
        <Arg>jdbc/mybd1</Arg>
        <Arg>
            <New class="com.mchange.v2.c3p0.ComboPooledDataSource">
                <Set name="driverClass">com.microsoft.sqlserver.jdbc.SQLServerDriver</Set>
                 <Set name="jdbcUrl">jdbc:jtds:sqlserver://url:1433/mybd1</Set>
                 <Set name="user">xx</Set>
                 <Set name="password">yy</Set>
            </New>
        </Arg>
    </New>

    <New id="ds2" class="org.eclipse.jetty.plus.jndi.Resource" >
        <Arg>jdbc/mybd2</Arg>
        <Arg>
            <New class="com.mchange.v2.c3p0.ComboPooledDataSource">
                <Set name="driverClass">com.microsoft.sqlserver.jdbc.SQLServerDriver</Set>
                <Set name="jdbcUrl">jdbc:jtds:sqlserver://url:1433/mybd2</Set>
                <Set name="user">xx</Set>
                <Set name="password">yy</Set>
            </New>
        </Arg>
    </New>
</Configure> 

的web.xml

<resource-ref>
    <res-ref-name>jdbc/mybd1</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <res-auth>Container</res-auth>
</resource-ref>
<resource-ref>
    <res-ref-name>jdbc/mybd2</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <res-auth>Container</res-auth>
</resource-ref>

hibernate.cfg.xml (还有另一个hibernate.cfb.xml来配置第二个数据源)

<session-factory>
  <property name="connection.datasource">jdbc/mybd1</property>
  <!-- ... -->

有任何线索吗?

4 个答案:

答案 0 :(得分:4)

我没有机会对其进行测试,但在我看来,您的问题是您错过了范围<Arg />

您的DS应该是:

    <New id="ds" class="org.eclipse.jetty.plus.jndi.Resource">
    <Arg></Arg>
    <Arg>jdbc/mybd1</Arg>
    <Arg>
        <New class="com.mchange.v2.c3p0.ComboPooledDataSource">

第一个“Arg”是范围,没有它,你的其他论点都不合适,可能会导致你的问题。

答案 1 :(得分:1)

尝试在Jetty中启用日志记录。 小心的记录器名称是“jndi”。 Jetty开发人员不使用class-name作为JNDI的logger-name。

我花了两天的时间来查找web.xml和jetty-env.xml中定义的名称之间的区别。

答案 2 :(得分:1)

id参数值应与jetty-env.xml和web.xml

匹配

<强>码头-env.xml

<Configure class="org.eclipse.jetty.webapp.WebAppContext">
    <New id="DS1" class="org.eclipse.jetty.plus.jndi.Resource">...</New>
    <New id="DS2" class="org.eclipse.jetty.plus.jndi.Resource">...</New>
</Configure> 

<强>的web.xml

<resource-ref id="DS1">...</resource-ref>
<resource-ref id="DS2">...</resource-ref>

答案 3 :(得分:1)

看看: https://www.eclipse.org/jetty/documentation/9.4.x/using-jetty-jndi.html

决定在哪里声明资源 您可以在三个位置定义命名资源:

<强>的jetty.xml jetty.xml文件中定义的命名资源的范围是JVM级别或服务器级别。 资源的类必须在Jetty容器级别可见。如果资源的类仅存在于webapp中,则必须在WEB-INF / jetty-env.xml文件中声明它。

<强> WEB-INF /码头-env.xml WEB-INF / jetty-env.xml文件中的命名资源的范围限定为文件所在的Web应用程序。虽然您可以选择输入JVM或服务器范围,但我们不建议您这样做。这里定义的资源可以使用您的webapp内部的类。这是一种特定于Jetty的机制。

上下文xml文件 上下文xml文件中的条目应限定在它们应用的webapp级别,但如果您选择,可以提供不太严格的服务器或JVM范围级别。与jetty.xml文件中声明的资源一样,与资源关联的类必须在容器的类路径上可见。

并放一个这样的文件:

     <?xml version="1.0"?>
 <!DOCTYPE Configure PUBLIC "-//Mort Bay Consulting//DTD Configure//EN" "http://jetty.mortbay.org/configure.dtd">

 <Configure class="org.eclipse.jetty.webapp.WebAppContext">

   <!-- Add an EnvEntry only valid for this webapp               -->
   <New id="gargle"  class="org.eclipse.jetty.plus.jndi.EnvEntry">
     <Arg>gargle</Arg>
     <Arg type="java.lang.Double">100</Arg>
     <Arg type="boolean">true</Arg>
   </New>

  <!-- Add an override for a global EnvEntry                           -->
   <New id="wiggle"  class="org.eclipse.jetty.plus.jndi.EnvEntry">
     <Arg>wiggle</Arg>
     <Arg type="java.lang.Double">55.0</Arg>
     <Arg type="boolean">true</Arg>
   </New>

   <!-- an XADataSource                                                -->
   <New id="mydatasource99" class="org.eclipse.jetty.plus.jndi.Resource">
     <Arg>jdbc/mydatasource99</Arg>
     <Arg>
       <New class="com.atomikos.jdbc.SimpleDataSourceBean">
         <Set name="xaDataSourceClassName">org.apache.derby.jdbc.EmbeddedXADataSource</Set>
         <Set name="xaDataSourceProperties">databaseName=testdb99;createDatabase=create</Set>
         <Set name="UniqueResourceName">mydatasource99</Set>
       </New>
     </Arg>
   </New>

 </Configure>