在受管理环境中,如JBoss应用服务器,由容器负责构造数据源,即javax.sql.DataSource的实例,然后把它发布为JNDI资源,Hibernate的DataSourceConnectionProviderImpl类充当这个数据源的代理,这个类位于org.hibernate.engine.jdbc.connections.internal包中。
有些Servlet容器,如Tomcat,也能负责构造数据源,并能把它发布为JNDI资源,因此Hibernate也能从Tomcat容器中获得数据源。
以Tomcat为例,为了使Hibernate从容器中获得数据源,需要分别配置Tomcat容器和Hibernate:
(1) 在Tomcat容器中配置数据源。
(2) 在Hibernate的配置文件中指定使用容器中的数据源。
1.在Tomcat容器中配置数据源
在Tomcat的配置文件server.xml中,元素用来配置JNDI 资源,Tomcat允许把数据源也发布为JNDI资源。以下代码在Tomcat中配置了一个JNDI名为“jdbc/SAMPLEDB”的数据源。
<!-- 在Tomcat的配置文件server.xml中配置数据源 -->
<GlobalNamingResources>
……
<Resource name="jdbc/SAMPLEDB"
auth="Container"
type="javax.sql.DataSource"
maxActive="100"
maxIdle="30"
maxWait="10000"
username="root"
password="1234"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/SAMPLEDB?autoReconnect=true"/>
</GlobalNamingResources>
在以上代码中, 元素用于定义名为jdbc/SAMPLEDB的数据源。
在server.xml文件的元素中配置的数据源能被Tomcat中的所有Java Web应用访问。
此外,还可以在一个Java Web应用的META-INF/context.xml文件中配置数据源,这个数据源只能被当前Java Web应用访问:
<Context reloadable="true" >
<Resource>……</Resource>
</Context>
2.在Hibernate的配置文件中指定使用容器中的数据源
在Hibernate的配置文件中,hibernate.connection.datasource属性用于指定容器中的数据源。以下配置代码指定Hibernate使用容器中JNDI名为“jdbc/SAMPLEDB”的数据源。
<!-- 使用容器中数据源的hibernate.properties文件 -->
hibernate.dialect=org.hibernate.dialect.MySQLDialect
hibernate.connection.datasource= java:comp/env/jdbc/SAMPLEDB
hibernate.show_sql=true
在指定数据源时,必须提供完整的JNDI名字。此外,由于Hibernate直接从容器中获得现成的数据源,因此在Hibernate的配置文件中,可以不用设定以下连接数据库的属性:
- hibernate.connection.url
- hibernate.connection.username
- hibernate.connection.password
对于使用JPA API的应用,在JPA的配置文件persistence.xml中还可以按照以下方式配置数据源:
<!—配置不支持JTA事务的数据源-->
<non-jta-data-source>jdbc/SAMPLEDB</non-jta-data-source>
<!—配置支持JTA事务的数据源-->
<jta-data-source>jdbc/JTA_SAMPLEDB</jta-data-source>