java – Tomcat如何从context.xml加载资源
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java – Tomcat如何从context.xml加载资源,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1861字,纯文字阅读大概需要3分钟。
内容图文
![java – Tomcat如何从context.xml加载资源](/upload/InfoBanner/zyjiaocheng/771/8edd9e353fbb40ca933f70b3081ecc0d.jpg)
希望有人可以清理一些东西 –
对于项目,我需要能够在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尝试创建数据源时,它会查找相应的资源信息并使用它
解决方法:
是的,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>
如您所见,您也可以使用其他声明.在我的情况下,我在这里注入外部配置位置,以便能够为属性配置器加载属性文件.因此,此位置将特定于应用程序.
内容总结
以上是互联网集市为您收集整理的java – Tomcat如何从context.xml加载资源全部内容,希望文章能够帮你解决java – Tomcat如何从context.xml加载资源所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。