我正在使用 Tomcat(版本 8.0.43)运行一个 Java Web 应用程序。
我将 tomcat-dbcp.jar(Tomcat8.0.43 附带)移至jdk/jre/lib/ext
jre 可用。
我认为我使用的是 Tomcat DBCP(而不是 Apache Commons DBCP),但正如我从文档中了解到的那样,配置参数与 Apache Commons DBCP 相同,详见此处。
Resource
因此,我在中为连接池设置了以下元素context.xml
:
<Resource
factory="org.apache.tomcat.jdbc.pool.DataSourceFactory"
auth="Container"
driverClassName="com.mysql.jdbc.Driver"
logAbandoned="false"
maxTotal="100"
maxIdle="30"
maxWaitMillis="10000"
name="jdbc/[dbName]"
password="${dbPassword}"
removeAbandonedOnBorrow="true"
removeAbandonedTimeout="60"
type="javax.sql.DataSource"
url="[dbUrl]autoReconnect=true"
username="${dbUsername}"
testWhileIdle="true"
testOnBorrow="true"
validationQuery="SELECT 1 AS dbcp_connection_test"/>
最近,我的日志中出现错误:
MySQLNonTransientConnectionException:连接太多
所以我检查了发生错误时我有多少连接(通过 Amazon CloudWatch for RDS。特别是“ConnectionCount”),它可以达到高达 150 个连接。如果我将maxTotal
连接数设置为 100,这怎么可能?
我在多个实例上运行我的应用程序。该maxTotal
属性是否适用于每个实例(例如:如果我在 2 个实例上定义了连接池,那么我的 maxTotal = 100 + 100 = 200?)
就好像我在Resource
元素中设置的属性被忽略了。可能是我的设置有问题吗?我没有像我想象的那样使用tomcat DBCP吗?
此外,如果我进一步Exception
查看上面引用的 StackTrack,我会看到
org.apache.tomcat.dbcp.dbcp2.BasicDataSource.getConnection
叫做。我不确定这是否意味着我使用的连接池 ( DBCP2
) 与我假设使用的连接池 (Tomcat DBCP) 不同。