- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不知道为什么每次有人访问我网站上的页面时,都会打开一个与数据库的新连接。最终我到达了大约 300 并收到错误并且页面不再加载。我认为它应该工作的方式是,我将 maxIdle 设置为 30,这意味着 Spring 打开的 hibernate 连接不应超过 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);
}
最佳答案
尝试此配置,这是对 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>
关于java - Spring 和 MySQL 连接(不断创建新连接而不是使用 hibernate 连接),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31010989/
如果这不是一个错误,那就是另一个错误。如果不是那样的话,那就是别的东西了。我觉得我的项目已经改变了很多,现在只是试图解决代码签名问题,结果一切都搞砸了。我严格按照说明进行操作,但出现错误,例如当前的“
我不确定是否有一些我不知道的内置变量或规则,或者 make 是否有问题,或者我只是疯了。 对于我的一个项目,我有一个如下的 makefile: CC=g++ CFLAGS=-O3 `libpng-co
我有大约 10 个 div,它们必须不断翻转,每个 div 延迟 3 秒 这个 codrops 链接的最后一个效果是我正在寻找的,但无需单击 div http://tympanus.net/Devel
我如何使用 jQuery 持续运行 PHP 脚本并每秒获取响应,以及将鼠标上的少量数据发送到同一脚本? 我真的必须添加一些随机扩展才能让这么简单的计时器工作吗? 最佳答案 To iterate is
JBoss 4.x EJB 3.0 我见过如下代码(大大简化): @Stateless @TransactionAttribute(TransactionAttributeType.NOT_SUPPO
使用 PHPStorm,我试图忽略每次尝试进行 git 提交时 pop 的 workspace.xml。 我的 .gitignore 看起来像: /.idea/ .idea/workspace.xml
我是一名优秀的程序员,十分优秀!