java - 从 context.xml 加载 Bean 属性值

标签 java xml spring context.xml

目前我们正在按照以下方式从属性文件加载 JDBC 源值:

<context:property-placeholder location="classpath:master.properties" ignore-unresolvable="true" />

<bean id="mainDataSource" class="com.jolbox.bonecp.BoneCPDataSource"
    destroy-method="close">
    <property name="driverClass" value="${database.driver}" />
    <property name="jdbcUrl" value="${database.url}" />
    <property name="username" value="${database.user}" />
    <property name="password" value="${database.password}" />
    <property name="idleConnectionTestPeriod" value="60" />
    <property name="idleMaxAge" value="240" />
    <property name="maxConnectionsPerPartition" value="2" />
    <property name="minConnectionsPerPartition" value="2" />
    <property name="partitionCount" value="3" />
    <property name="acquireIncrement" value="10" />
    <property name="statementsCacheSize" value="50" />
    <property name="releaseHelperThreads" value="3" />
</bean>

<bean id="dataSource"
    class="org.springframework.jdbc.datasource.LazyConnectionDataSourceProxy"
    scope="singleton">
    <property name="targetDataSource">
        <ref local="mainDataSource" />
    </property>
</bean>

这一段。适用于基于类路径的 app.properties 文件并摆脱 app.properties。

我们想从 context.xml(放在 META-INF$CATALINA_HOME/conf/context.xml 中)加载这些值。它将帮助我们在生产/登台服务器上加载正确的值。

将不胜感激任何帮助或替代方法/建议。 (如果类似问题已经回答,请分享链接) 谢谢!

最佳答案

正如 Alan Hay 提到的,您可以将数据源配置外部化到 Tomcat 自己的 context.xml 中,然后让 Spring 执行 JNDI 查找来检索它。这是我在我从事的一些项目中常用的方法。

您需要采取的措施是:

<强>1。将数据源配置添加到 $CATALINA_HOME/conf/context.xml

<GlobalNamingResources>

    <Resource type="javax.sql.DataSource" 
              name="dsName"
              factory="com.jolbox.bonecp.BoneCPDataSource" 
              driverClassName="your.driver.classname"
              jdbcUrl="your:driver:url" 
              username="username"
              password="password" 
              idleMaxAge="240" 
              idleConnectionTestPeriod="60"
              partitionCount="3" 
              acquireIncrement="10" 
              maxConnectionsPerPartition="2"
              minConnectionsPerPartition="2" 
              statementsCacheSize="50"
              releaseHelperThreads="3" />

</GlobalNamingResources>

<强>2。在应用的META-INF/context.xml中添加资源链接

<Context path="/YourApp">
    <ResourceLink description="Datasource for YourApp" 
                  global="jdbc/dsName"
                  name="jdbc/dsName" 
                  type="javax.sql.DataSource" />        
</Context>

<强>3。修改 Spring 配置以在 JNDI 中查找数据源

<beans xmlns:jee="http://www.springframework.org/schema/jee"
       xsi:schemaLocation="http://www.springframework.org/schema/jee classpath:/org/springframework/ejb/config/spring-jee-3.0.xsd">

    <jee:jndi-lookup id="dataSource" 
                     jndi-name="java:comp/env/jdbc/dsName" />

<强>4。移动驱动程序和数据源 jar

由于数据源配置现在是容器管理的,您应该将数据库驱动程序和数据源 jar 放入 $CATALINA_HOME/lib 中,以便 Tomcat 在创建数据源时可以使用它们。这些 jar 应该不再需要驻留在您的应用程序的 WEB-INF/lib 中。

关于java - 从 context.xml 加载 Bean 属性值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19386905/

相关文章:

java - 在 Java EE 中缓存 DataSource 查找是否安全?

java - 使用hibernate和jdbc进行性能测试

java - 如何在 Android 中动态包含布局?

android - 很难将 child 与另一个 child 之间的最左和最右对齐

python - 转换自定义 XML 类语法的最佳方式

java - Spring Boot 集成测试 - 在应用程序上下文启动之前模拟 @Service?

java - Spring 为有效 URL 生成 404

java - Android访问IO

java - 模拟 Apache Commons CSV CSVRecord

java - Spring Boot RestController 继承和不明确的映射问题