Spring 和 MySQL 连接(不断创建新连接而不是使用休眠连接)

问题描述 投票:0回答:1

我不知道为什么每次有人访问我网站上的页面时,都会打开一个与数据库的新连接。最终我到达了大约 300 并收到错误并且页面不再加载。我认为它应该工作的方式是,我将 maxIdle 设置为 30,这意味着 Spring 打开的睡眠连接不应超过 30 个。但此时我有88空着。如果我关闭或重新启动我的服务器,它会回落到接近 0。我对每个查询都使用 getJdbcTemplate() 。

这是我的 spring-config.xml 的一部分

<bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close">
    <property name="driverClassName" value="com.mysql.jdbc.Driver" />
    <property name="url" value="XXXXXXXXX" />
    <property name="username" value="XXXXXXXXXX" />
    <property name="password" value="XXXXXXXX" />
    <property name="maxIdle" value="30"/>
    <property name="defaultAutoCommit" value="true"/>
</bean>

这是 dao 的部分(重命名)

@Repository
public class ExampleDAOImpl extends JdbcDaoSupport implements ExampleDAO {

@Autowired
public ExampleDAOImpl(DataSource dataSource) {
    setDataSource(dataSource);
}

这是我从 MySQL 中的 show processlist 得到的结果(这里没有显示所有行,有 88 行)

+----------+------------+-------------------------------------------+------+---------+-------+----------------+---------------------
| Id       | User       | Host                                      | db   | Command | Time  | State          | Info             db
+----------+------------+-------------------------------------------+------+---------+-------+----------------+-----------------------
| 21721763 | user | XXXXXXXX:60586 | db | Sleep   | 10609 |                | NULL             db
| 21924432 | user | XXXXXXXX:59498 | db | Query   |     0 | NULL           | show processlist db
| 21924580 | user | XXXXXXXX:59702 | db | Sleep   |   790 |                | NULL             db
| 21924722 | user | XXXXXXXX:60010 | db | Sleep   |   790 |                | NULL             db
| 21924813 | user | XXXXXXXX:60131 | db | Sleep   |   787 |                | NULL             db
| 21924819 | user | XXXXXXXX:60139 | db | Sleep   |   786 |                | NULL             db
| 21924841 | user | XXXXXXXX:60156 | db | Sleep   |   785 |                | NULL             db
| 21927089 | user | XXXXXXXX:56292 | db | Query   |     1 | Opening tables | XXXXXXXX |
| 21927090 | user | XXXXXXXX:56295 | db | Query   |     1 | Opening tables | XXXXXXXX |
88 rows in set (0.01 sec)

dao 方法示例

public String selectSomething(String text) throws IllegalArgumentException, DAOException {
     return (String) getJdbcTemplate().queryForObject(SELECT_QUERY_1, new Object[] {text}, String.class);
}
java mysql spring connection
1个回答
2
投票

尝试此配置,这是对 PROD 环境进行多次调整的结果:

    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
        <property name="driverClassName" value="com.mysql.jdbc.Driver">
        <property name="url" value="XXX" />
        <property name="username" value="XXX"/>
        <property name="password" value="XXX"/>
        <property name="minIdle" value="0"/>
        <property name="maxIdle" value="10"/>
        <property name="maxActive" value="50"/>
        <property name="maxWait" value="60000"/>
        <property name="testOnBorrow" value="true"/>
        <property name="validationQuery" value="SELECT 1"/>               
        <property name="timeBetweenEvictionRunsMillis" value="1800000"/>
        <property name="numTestsPerEvictionRun" value="50"/>
        <property name="minEvictableIdleTimeMillis" value="10"/>
        <property name="testWhileIdle" value="true"/>
    </bean>     
© www.soinside.com 2019 - 2024. All rights reserved.