给别人用springmvc 做的一个网站,数据库用的proxool配的连接池,服务器用的tomcat。但是启动后cpu占用率一下就上去了,阿里云的服务器,单核,2G内存,windows 2012
<?xml version="1.0" encoding="UTF-8"?>
<something-else-entirely>
<proxool>
<alias>mysql</alias>
<driver-url>jdbc:mysql://127.0.0.1:3306/lingshang1?rewriteBatchedStatements=true&useUnicode=true&characterEncoding=UTF-8</driver-url>
<driver-class>com.mysql.jdbc.Driver</driver-class>
<driver-properties>
<property name="user" value="root" />
<property name="password" value="root" />
</driver-properties>
<house-keeping-sleep-time>90000</house-keeping-sleep-time>
<prototype-count>5</prototype-count>
<maximum-connection-count>50</maximum-connection-count>
<minimum-connection-count>5</minimum-connection-count>
</proxool>
</something-else-entirely>
建议你去检查下mysql本身的配置.很多时候是由于mysql本身的配置,导致你的程序在getconnections的时候大量的等待时间,
而你又强制要求了最小连接数.所以程序一直在不停的去拿数据库连接.
首先,看下项目代码中的连接资源使用完成后是否及时关闭了呢?
其次,proxool连接池配置中有一项houseKeepingTestSql,只有添加了这一项proxool才会自动侦测各个连接的状态并决定是否销毁或创建。
这是由于proxool中有两个监控线程使用了while(true),这就占据了两个线程的CPU处理能力,以我的CPU,4核8线程,就相当于占据了一个核的运算量,即有一个CPU看起来是100%的使用率。
目前这个问题还无法避免。
我刚刚测试了proxool, c3p0, hikaricp这3个连接池,还是hikaricp的效率高,但稳定性尚不知,另外hikaricp需要jdk1.7及以上的环境,对老系统来说,还不能使用。
建议换用c3p0吧,效率比proxool要高出一些。从其它评测来看,稳定性也不如c3p0。
还有其它人推荐的druid,没有测试过,不清楚如何。