Mybatis框架的连接池配置

更新时间:2023-05-12 01:43:19 阅读: 评论:0

Mybatis框架的连接池配置
啥也不说,先上代码:
xml配置:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-////DTD Config 3.0//EN"
"/dtd/mybatis-3-config.dtd">
<configuration>
<environments default="mysql_development">
<!-- 连接环境信息 -->
<environment id="mysql_development">
<!-- mysql使⽤什么事物管理⽅式 -->
<transactionManager type="JDBC">
<property name=""value="" />
</transactionManager>
<!-- mybatis使⽤连接池⽅式来获取连接对象 -->
<dataSource type="POOLED">
<!-- 配置数据库连接信息 -->
<property name="driver"value="sql.jdbc.Driver" />
<property name="url"value="jdbc:mysql://your_mysql_url:3306/your_db_name?uUnicode=true&characterEncoding=utf-8" />
<property name="urname"value="root" />
<property name="password"value="your_password" />
<property name="poolMaximumIdleConnections"value="0"/>
<property name="poolMaximumActiveConnections"value="1000"/>
<property name="poolPingQuery"value="SELECT 1 FROM DUAL" />
<property name="poolPingEnabled"value="true" />
</dataSource>
</environment>
</environments>
<mappers>
<package name="bean.map"/>
</mappers>
</configuration>
说明:上⾯都是很显然的,有⼏个地⽅注意
url中uUnicode=true&characterEncoding=utf-8 注意⾥⾯的转义字符&;也就是&,否则会出错的
后⾯两个参数poolMaximumIdleConnections,和poolMaximumActiveConnections,需要并发控制的时候必须调整这俩参数
poolMaximumActiveConnections是最⼤的活动连接数,活动连接,就是正在与数据库交互的连接,默认是10
poolMaximumIdleConnections是空闲连接数,就是没有处理请求的连接,默认是5
具体可以参考mybatis的源码org.apache.ibatis.datasource.pooled.PooledDataSource.
注意:
PooledDataSource就是连接池的实现类。可以看到⾥⾯定义了⼏个参数,其中就包
括poolMaximumActiveConnections和poolMaximumIdleConnections,找到pushConnection⽅法,这个⽅法⾥会判断当前空闲连接数
和poolMaximumIdleConnections的⼤⼩,如果⼩于poolMaximumIdleConnections,会new PooledConnection并放进队列中,这就导致⼀个问题,当所有的连接被占满后,Mybatis为了保持⼀定的空闲连接,会不断获取新的连接,然后这些新连接被占⽤后,就会再去new PooledConnection,如果⼀直这样new下去,结果就会超过了mysql设置的最⼤连接数max_connections,然后数据库返回错误:too many connections。

本文发布于:2023-05-12 01:43:19,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/89/885758.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:连接   数据库   超过   空闲   时候   控制   信息   看到
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图