## 数据库连接池 --- ### SQL生命周期: 1. 应用服务器与数据库服务器建立一个连接 2. 数据库进程拿到请求sql 3. 解析并生成执行计划,执行 4. 读取数据到内存并进行逻辑处理 5. 通过步骤一的连接,发送结果到客户端 6. 关掉连接,释放资源 其中的连接在里面发挥着重大作用,但频繁的创建和销毁,非常浪费系统资源。由于数据库更适合长连接,也就有个连接池,能对连接复用,维护连接对象、分配、管理、释放,也可以避免创建大量的连接对DB引发的各种问题;另外通过请求排队,也缓解对DB的冲击。 连接池在初始化时创建MIN个连接。如果有业务请求,而此时没有空闲的管道,如果没有达到MAX连接数,无需等待,会申请创建一个新的连接。如果已经达到MAX,只能排队等待,等待的时间取决于block-timeout,如果超过等待时间没有拿到连接,抛拿不到连接的异常。 ### 推荐开源框架: Druid首先是一个数据库连接池,但它不仅仅是一个数据库连接池,它还包含一个ProxyDriver,一系列内置的JDBC组件库,一个SQL Parser。 [https://mp.weixin.qq.com/s/SRB0yruUIdmG9z8lXnJ-Ag](https://mp.weixin.qq.com/s/SRB0yruUIdmG9z8lXnJ-Ag) **附加功能**: * 监控,比如打印每一条sql详情,统计慢sql * 统计,sql调用次数、时间等 * 安全,比如防御SQL注入攻击,数据库密码加密等 * 支持spring boot ``` com.alibaba druid 1.0.9 ```` ``` ``` 接口文档注释: http://tool.oschina.net/apidocs/apidoc?api=druid0.26 ### 其它 * [数据库连接池极简教程](https://mp.weixin.qq.com/s/tLysIX9KChNioJ-fMMimxw) * [阿里巴巴开源项目 Druid 负责人温少访谈](http://www.iteye.com/magazines/90)