自定义连接池
当需要根据一个输入的信息,执行大量的IO/数据库操作时,此时池的源不固定,可以使用自定义连接池,common-pool2已经给了框架,防止重复造轮子。
注:池提供的关键能力:
(1)最小连接数、最大连接数与超时时间:
如果当前连接数小于最小连接数,则创建新的连接处理数据库请求
如果线程池中有空闲连接,则使用空闲连接
如果没有空闲连接,并且当前连接数小于最大连接数,则继续创建新的连接
如果当前连接数大于等于最大连接数,并且没有空闲连接了,则请求按照超时时间等待旧连接可用。
超时之后,则获取数据库连接失败 (2)
依赖版本
<dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-pool2</artifactId> <version>2.4.2</version> </dependency>
common-pool原理
Jedis优秀案例1
实战案例1 -- 根据给定的数据地址,创建连接池
package com.home.handler;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.pool2.impl.GenericKeyedObjectPool;
imp