com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60000, active 5, maxActive 5, creating 0


druid連接池,部署到服務器之后,當並發用戶開始增大時,tomcat頻繁報錯:

com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60000, active 5, maxActive 5, creating 0

github 上面的issue里面也沒有好的解決方法:https://github.com/alibaba/druid/issues/2130

之前遇到過一次,通過升級 druid版本和mysql去掉解決了,后來遷移服務器,有遇到這個報錯。升級版本解決不了。

最后換了 HikariCP 連接池,不得不說,真他么香!為啥沒有早點換呢????

github地址:https://github.com/brettwooldridge/HikariCP

配置如下:

        <!-- Hikari Datasource -->
         <bean id="dataSource" class="com.zaxxer.hikari.HikariDataSource"  destroy-method="close">
          <!-- <property name="driverClassName" value="${db.driverClass}" /> --> <!-- 無需指定,除非系統無法自動識別 -->
          <property name="jdbcUrl" value="${jdbc_url}" />
          <property name="username" value="${jdbc_username}" />
          <property name="password" value="${jdbc_password}" />
           <!-- 連接只讀數據庫時配置為true, 保證安全 -->
          <property name="readOnly" value="false" />
          <!-- 等待連接池分配連接的最大時長(毫秒),超過這個時長還沒可用的連接則發生SQLException, 缺省:30秒 -->
          <property name="connectionTimeout" value="30000" />
          <!-- 一個連接idle狀態的最大時長(毫秒),超時則被釋放(retired),缺省:10分鍾 -->
          <property name="idleTimeout" value="600000" />
          <!-- 一個連接的生命時長(毫秒),超時而且沒被使用則被釋放(retired),缺省:30分鍾,建議設置比數據庫超時時長少30秒,參考MySQL wait_timeout參數(show variables like '%timeout%';) -->
          <property name="maxLifetime" value="1800000" />
          <!-- 連接池中允許的最大連接數。缺省值:10;推薦的公式:((core_count * 2) + effective_spindle_count) -->
          <property name="maximumPoolSize" value="50" />
          <property name="connectionInitSql" value="set names utf8mb4" />
         </bean>

  

特別需要注意的是 maxnumPoolSize 千萬不要設置的很高!!!其實感覺我這里設置為 50 都有點高了。

HikariCP 在速度和穩定性上面比 Druid 好太多了,再也不願意使用Druid了!!!

有用的參考:https://blog.csdn.net/clementad/article/details/46928621

https://github.com/brettwooldridge/HikariCP/wiki/Bad-Behavior:-Handling-Database-Down

https://github.com/brettwooldridge/HikariCP/wiki/MySQL-Configuration

https://cdn.oreillystatic.com/en/assets/1/event/21/Connector_J%20Performance%20Gems%20Presentation.pdf

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM