目前我们正在按照以下内容从属性文件加载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>
这个段。适用于基于classpath的app.properties文件并摆脱app.properties。
我们希望从context.xml加载此值(放在META-INF
或$CATALINA_HOME/conf/context.xml
中)。它将帮助我们在prod / staging服务器上加载正确的值。
欢迎任何帮助或替代方法/建议。 (如果已经回答了类似的问题,请分享链接) 谢谢!
答案 0 :(得分:3)
我这样做,我的classpath中有默认属性文件,我有一个属性文件用于覆盖那些默认(开发)属性:
在我的春季文件中:
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="ignoreResourceNotFound" value="true"/>
<property name="locations">
<list>
<value>classpath:jdbc.properties</value>
<value>classpath:camel.properties</value>
<value>classpath:email.properties</value>
<value>${external_config}</value>
</list>
</property>
</bean>
在开发中,我使用类路径中的属性文件 在不同的环境,分段,集成,生产中,我们使用以下参数启动应用程序:
-Dexternal_config=file:c:/staging.properties
这样我可以为所有环境提供相同的构建,并可以选择覆盖属性文件的位置。
因此,${external_config}
是依赖于环境的配置文件的占位符。
Spring查找名为external_config的环境变量,该变量应指向配置文件。如果找不到该文件,Spring会忽略ignoreResourceNotFound = true;
答案 1 :(得分:3)
正如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中。
答案 2 :(得分:1)
Spring 3.1引入了对特定于环境的配置文件的支持。定义一些配置文件,将它们与一些属性文件相关联test.properties,live.properties并在服务器上设置环境变量start -Dspring.profiles.active = Test。干净简单。
http://spring.io/blog/2011/02/11/spring-framework-3-1-m1-released/
上面提到的其他选项是转移到通过JNDI查找的容器托管连接池,即在每个服务器上定义名为xyz的JNDI数据源,然后: