4

我正在使用 Tomcat(版本 8.0.43)运行一个 Java Web 应用程序。

我将 tomcat-dbcp.jar(Tomcat8.0.43 附带)移至jdk/jre/lib/extjre 可用。

我认为我使用的是 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) 不同。

4

1 回答 1

0

maxTotal 属性是否适用于每个实例(例如:如果我在 2 个实例上定义了连接池,那么我的 maxTotal = 100 + 100 = 200?)

这是正确的,因为您已经<Resource>context.xml文件中定义了您的内容。
在 中添加您的资源server.xml以使其可用于所有上下文,并确保将其从所有 context.xml 文件中删除。记下global配置中不存在的属性

<GlobalNamingResources>
    <Resource
        global="jdbc/[dbName]"

        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"/>
</GlobalNamingResources>

密切关注:

  • testOnBorrow="true"导致性能损失并不总是值得的。

  • testWhileIdle="true"timeBetweenEvictionRunsMillis哪个相关,默认为 5 秒。在某些情况下,默认值可能太短。

  • 验证未超出AWS RDS 配额。

于 2019-04-15T17:22:42.703 回答