Java 连接太多(新错误)

Java 连接太多(新错误),java,tomcat,connection-pooling,Java,Tomcat,Connection Pooling,好的,我更改了连接工厂代码,使用了PoolProperties类,现在出现以下错误: 数据源拒绝建立连接,来自服务器的消息:“连接太多” 在我的InsertandGetObject方法中,我记录了一条消息,以便测试连接是否正在关闭,并且是否正在关闭,我还将在服务器上消除bug 对这个问题有什么想法吗 这是我的连接池: public static Connection getConnection() throws DatabaseConnectionException { Poo

好的,我更改了连接工厂代码,使用了PoolProperties类,现在出现以下错误:

数据源拒绝建立连接,来自服务器的消息:“连接太多”

在我的InsertandGetObject方法中,我记录了一条消息,以便测试连接是否正在关闭,并且是否正在关闭,我还将在服务器上消除bug

对这个问题有什么想法吗

这是我的连接池:

    public static Connection getConnection() throws DatabaseConnectionException {

    PoolProperties p = new PoolProperties();
    p.setName("jdbc/MetaData");
    p.setUrl("jdbc:mysql://localhost:3306/db_name");
    p.setDriverClassName("com.mysql.jdbc.Driver");
    p.setUsername("root");
    p.setPassword("");
    p.setInitialSize(3);
    p.setMaxActive(10);
    p.setMaxIdle(8);
    p.setMinIdle(2);
    p.setRemoveAbandoned(true);
    p.setMaxWait(10000);

    Connection conn = null;



    try {

        DataSource dataSource = new org.apache.tomcat.jdbc.pool.DataSource(p);

        conn = dataSource.getConnection();

    } catch (SQLException e) {
        LOGGER.debug("MSJ SQLExp: " + e.getMessage());
        throw new DatabaseConnectionException(e);

    } 

    return conn;
}
这是关闭连接的方法:

    public Concept insertAndGetObject(Concept object) throws SQLException,
        DatabaseConnectionException {
    try {

        connection = ConnectionFactory.getConnection();
        connection.setAutoCommit(false);
        statement = connection.prepareStatement(INSERT_CONCEPTS);
        statement = ConceptMapperUtil.setStatementParameters(statement,
                object);
        statement.executeUpdate();
        connection.commit();
        LOGGER.debug("Inserted concept row ");
    } catch (SQLException e) {
        connection.rollback();

        if (e.getErrorCode() == SQL_INSERT_ERROR_CODE) {
            LOGGER.debug("Concept already exists!");
        } else {
            throw e;
        }

    } finally {
        object = findConceptByUniqueFk(object.dataSource.getIdDataSource(),
                object.conceptType.getIdConcept(),
                object.idMetadataVersion.getIdMetaDataVersion());
        DbUtil.close(statement);
        // connection.setAutoCommit(true);
        DbUtil.close(connection);
    }
    return object;
}
使用
newdatasource(PoolProperties)
不会创建“包装连接的数据源对象”(如中所述)。相反,您创建一个连接池(也在ApiDocs中提到,但在顶部:“数据源只是包装了一个连接池…”)。我在源代码中验证了这一点(参见第108行)


因此,关闭连接只会将其返回到池中(以便可以重复使用),而不会实际关闭连接(除非您看到数据库服务器上的连接实际上正在关闭,在这种情况下,我错了)。解决方案是创建一个数据源对象,并在每次调用
getConnection()
时重复使用它。当应用程序不再需要数据库连接时,关闭DataSource/ConnectionPool。

严格来说,这与您的问题无关,但为什么您(1)在方法开始时没有获得
概念,以避免将异常用作“正常”业务逻辑(插入已存在的概念是“正常的”)(2)当有可能引发严重的SQLException,并且您的连接处于无效状态时,是否返回到finally子句中的数据库?这第二点甚至可以解释您的问题,尽管我不能用您提供的信息来说明。我做了一些更改,现在我发现了这个错误,知道吗?您的应用程序正在接收多少请求(或同时请求)?您的数据库配置为处理多少个simultaneos连接?尝试增加mysql允许的连接数(通过mysql管理员或编辑my.ini),在最后一个块中,您在一行中调用DbUtil.close两次DbUtil.close(语句)->首先(使用语句作为参数),然后调用DbUtil.close(连接),这次将连接作为参数传递