gpt4 book ai didi

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

转载 作者:数据小太阳 更新时间:2023-10-29 02:02:56 25 4
gpt4 key购买 nike

目前我们正在按照以下方式从属性文件加载 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com