[英]How to preinitialize DBCP connection pool on startup?
我的项目设置是 -
这是我的应用程序的日志,它捕获与数据库的交互。
2013-01-29 15:52:21,549 DEBUG http-bio-8080-exec-3 org.springframework.jdbc.core.JdbcTemplate - Executing SQL query [SELECT id from emp]
2013-01-29 15:52:21,558 DEBUG http-bio-8080-exec-3 org.springframework.jdbc.datasource.DataSourceUtils - Fetching JDBC Connection from DataSource
2013-01-29 15:52:31,878 INFO http-bio-8080-exec-3 jdbc.connection - 1. Connection opened org.apache.commons.dbcp.DriverConnectionFactory.createConnection(DriverConnectionFactory.java:38)
2013-01-29 15:52:31,878 DEBUG http-bio-8080-exec-3 jdbc.connection - open connections: 1 (1)
2013-01-29 15:52:31,895 INFO http-bio-8080-exec-3 jdbc.connection - 1. Connection closed org.apache.commons.dbcp.DelegatingConnection.close(DelegatingConnection.java:247)
2013-01-29 15:52:31,895 DEBUG http-bio-8080-exec-3 jdbc.connection - open connections: none
2013-01-29 15:52:41,950 INFO http-bio-8080-exec-3 jdbc.connection - 2. Connection opened org.apache.commons.dbcp.DriverConnectionFactory.createConnection(DriverConnectionFactory.java:38)
2013-01-29 15:52:41,950 DEBUG http-bio-8080-exec-3 jdbc.connection - open connections: 2 (1)
2013-01-29 15:52:52,001 INFO http-bio-8080-exec-3 jdbc.connection - 3. Connection opened org.apache.commons.dbcp.DriverConnectionFactory.createConnection(DriverConnectionFactory.java:38)
2013-01-29 15:52:52,002 DEBUG http-bio-8080-exec-3 jdbc.connection - open connections: 2 3 (2)
2013-01-29 15:53:02,058 INFO http-bio-8080-exec-3 jdbc.connection - 4. Connection opened org.apache.commons.dbcp.DriverConnectionFactory.createConnection(DriverConnectionFactory.java:38)
2013-01-29 15:53:02,058 DEBUG http-bio-8080-exec-3 jdbc.connection - open connections: 2 3 4 (3)
2013-01-29 15:53:03,403 DEBUG http-bio-8080-exec-3 org.springframework.jdbc.core.BeanPropertyRowMapper - Mapping column 'id' to property 'id' of type int
2013-01-29 15:53:04,494 DEBUG http-bio-8080-exec-3 org.springframework.jdbc.datasource.DataSourceUtils - Returning JDBC Connection to DataSource
从日志中可以清楚地看到两件事 -
我的问题是 -
注意:请不要建议切换到C3P0或Tomcat连接池。 我知道那些解决方案。 我更感兴趣的是了解手头的问题,而不仅仅是快速修复。 此外,我确信DBCP也应该有一些基本的东西。
dbcontext的内容 -
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${db.driver}" />
<property name="url" value="${db.jdbc.url}" />
<property name="username" value="${db.user}" />
<property name="password" value="${db.password}" />
<property name="maxActive" value="20" />
<property name="initialSize" value="4" />
<property name="testOnBorrow" value="true" />
<property name="validationQuery" value="SELECT 1" />
</bean>
在您首次请求连接之前,initialSize不会生效。 从java docs到BasicDataSource #setInitialSize
设置连接池的初始大小。
注意:一旦池初始化,此方法当前不起作用。 第一次调用以下方法之一时初始化池:getConnection,setLogwriter,setLoginTimeout,getLoginTimeout,getLogWriter。
尝试将init-method="getLoginTimeout"
到bean中以确认这一点。
对于Web应用程序,您可以使用DataAccess层实现ServletContextListener.contextInitialized()
方法并触发测试查询(例如,从Emp Limit 1中选择ID)。 这应该初始化您的连接池,并在您的应用程序开始从Web提供真实用户之前使其准备就绪。
看一下initialSize
属性 - 特别是有关何时初始化池的部分。 正如sbridges指出的那样,您可以使用bean上的init-method
属性来调用其中一个方法来触发池创建。
此外,您应该研究为什么平均需要7.5秒来创建连接...
干杯,
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.