希望有人可以清理一些事情 -
对于项目,我需要能够在Sybase和Oracle数据库之间切换。使用Spring我已经使用AbstractRoutingDataSource提出了一个解决方案,允许根据需要在sybase和oracle数据源之间进行切换。
但是,在我的tomcat context.xml中,我列出了所有数据源 - 因此对于每一个我都有“jdbc / myDbSybaseDataSource”和“jdbc / myDbOracleDataSource”。我想知道,tomcat是否会在启动时尝试创建所有这些数据源,还是等到代码中的某些内容调用它?
我知道在春天你可以懒加载你的bean,但tomcat仍然会在context.xml中创建每个资源吗?
非常感谢任何帮助!
修改的
询问的原因是 - 例如,如果Sybase数据库已关闭,我们需要知道我们可以切换到Oracle,但Tomcat不会尝试在启动时从context.xml加载Sybase资源(不幸的是,我无法关闭其中一个数据库来测试这个!:))。
据我所知,Tomcat正在加载资源 - 但是在部分代码调用数据源之前不会尝试实际连接到数据库,此时Spring会启动并完成其工作。它只是加载资源并将信息保存在某个地方,当Spring尝试创建数据源时,它会查找相应的资源信息并使用此
答案 0 :(得分:1)
是的,Tomcat将在启动时创建这些数据源。我无法告诉你这个初始化的进展有多远,但我会尽量避免你不需要的任何开销。
您是否需要在运行时使用这两个数据源,或者只是为了能够在启动时确定您的应用程序?
在第二种情况下,您可以将cotext.xml文件视为(外部)配置文件。然后,您可以使用spring jndi reference feature连接到当前应用程序所需的数据库。
在root-context.xml中,您可以按名称引用ONE数据源:
<jee:jndi-lookup id="mvcDatasource" jndi-name="jdbc/mvcDatasource"
expected-type="javax.sql.DataSource" />
根据应使用的类型,您可以在context.xml中声明正确的实现:
<Context>
<Environment name="configDirectory" type="java.lang.String" value="file:///tmp/app1" />
<Resource name="jdbc/mvcDatasource" type="javax.sql.DataSource" auth="Container" driverClassName="org.h2.Driver" maxActive="8" maxIdle="4" username="user" password="" url="jdbc:h2:file:/tmp/app1/db" />
</Context>
如您所见,您也可以使用其他声明。在我的情况下,我在这里注入外部配置位置,以便能够为属性配置器加载属性文件。所以这个位置将是特定于应用程序的。