【发布时间】:2014-08-10 09:48:09
【问题描述】:
我有一个传统的 Tomcat Web 应用程序,它使用 JNDI 连接到 Postgres DB(读取 context.xml)。 在 AWS EBS 中,可以使用系统属性来读取特定的东西,比如 jdbc 连接参数,这将非常适合在不同的环境(开发、登台、生产)中轻松使用相同的包,而无需更改 context.xml 文件. 由于我使用的是JNDI DataSource,所以我访问的是原始数据源,然后更改url和密码,这样:
org.apache.tomcat.jdbc.pool.DataSource ds = (DataSource) new InitialContext().lookup("java:/comp/env/jdbc/myapp");
String jdbcURL = System.getProperty("JDBC_CONNECTION_STRING");
String username = System.getProperty("PARAM1");
String password = System.getProperty("PARAM2");
if (!StringUtils.isEmpty(jdbcURL)){
ds.setUrl(jdbcURL);
ds.setUsername(username);
ds.setPassword(password);
}
使用 Tomcat 数据源我可以访问连接参数的设置器和获取器。 在本地测试(在Tomcat的VM参数中添加系统参数,它工作得很好。 但是当我在AWS EBS中上传到我的测试环境时,这些参数一开始是空的(当应用程序加载时),但它们稍后可用:以这种方式在jsp页面中测试它们
The JDBC_CONNECTION_STRING environment property is:
<%= System.getProperty("JDBC_CONNECTION_STRING") %>
</p>
<p>
The PARAM1 environment property is:
<%= System.getProperty("PARAM1") %>
</p>
<p>]
The PARAM2 environment property is:
<%= System.getProperty("PARAM2") %>
</p>
并打印正确的值。 我唯一的猜测是系统属性是稍后加载的,而我在应用程序启动时调用的侦听器中设置了与数据库的连接(在 web.xml 中设置)。
知道为什么会失败吗?
谢谢,
罗希
编辑:我找到了问题,但没有找到解决方案: 问题是在lookup() 方法中加载DataSource 时,它也尝试建立连接!它不会成功,因为 context.xml 中的 url 是 localhost,而我在部署时没有数据库。
任何人都知道如何不立即连接,而是等到第一个 getConnection() 调用? 这是我的 context.xml
<Resource auth="Container"
driverClassName="org.postgresql.Driver"
factory="org.apache.tomcat.jdbc.pool.DataSourceFactory"
maxActive="1000" maxIdle="1000" maxWait="2000"
autoReconnect="true"
logAbandoned="true"
name="jdbc/townflix"
type="org.apache.tomcat.jdbc.pool.DataSource"
url="jdbc:postgresql://localhost:5432/mydb?prepareThreshold=3"
username="user"
password="pass"
/>
【问题讨论】:
标签: java amazon-web-services tomcat7 amazon-elastic-beanstalk