如何使用Tomcat在春季提供的JNDI数据源?

2022-08-31 07:15:34

据说在Spring javadoc关于类的文章中,这个类非常简单,建议DriverManagerDataSource

以使用容器提供的 JNDI 数据源。这样的可以在Spring ApplicationContext中作为Bean公开,通过以下方式DataSourceDataSourceJndiObjectFactoryBean

问题是:我该如何做到这一点?

例如,如果我希望Bean访问我的自定义MySQL数据库,那么我需要什么呢?我应该在上下文配置等中写些什么?DataSource


答案 1

如果使用Spring的基于XML模式的配置,请在Spring上下文中进行如下设置:

<beans xmlns="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns:jee="http://www.springframework.org/schema/jee" xsi:schemaLocation="
    http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee.xsd">
...
<jee:jndi-lookup id="dbDataSource"
   jndi-name="jdbc/DatabaseName"
   expected-type="javax.sql.DataSource" />

或者,使用简单的bean配置进行设置,如下所示:

<bean id="DatabaseName" class="org.springframework.jndi.JndiObjectFactoryBean">
    <property name="jndiName" value="java:comp/env/jdbc/DatabaseName"/>
</bean>

您可以在 tomcat 的服务器中声明 JNDI 资源.xml使用如下内容:

<GlobalNamingResources>
    <Resource name="jdbc/DatabaseName"
              auth="Container"
              type="javax.sql.DataSource"
              username="dbUser"
              password="dbPassword"
              url="jdbc:postgresql://localhost/dbname"
              driverClassName="org.postgresql.Driver"
              initialSize="20"
              maxWaitMillis="15000"
              maxTotal="75"
              maxIdle="20"
              maxAge="7200000"
              testOnBorrow="true"
              validationQuery="select 1"
              />
</GlobalNamingResources>

并从Tomcat的Web上下文中引用JNDI资源.xml如下所示:

  <ResourceLink name="jdbc/DatabaseName"
   global="jdbc/DatabaseName"
   type="javax.sql.DataSource"/>

参考文档:

编辑:此答案已针对Tomcat 8和Spring 4进行了更新。Tomcat 的默认数据源资源池设置发生了一些属性名称更改。


答案 2

使用Spring的JavaConfig机制,你可以这样做:

@Configuration
public class MainConfig {

    ...

    @Bean
    DataSource dataSource() {
        DataSource dataSource = null;
        JndiTemplate jndi = new JndiTemplate();
        try {
            dataSource = jndi.lookup("java:comp/env/jdbc/yourname", DataSource.class);
        } catch (NamingException e) {
            logger.error("NamingException for java:comp/env/jdbc/yourname", e);
        }
        return dataSource;
    }

}

推荐