时间:2021-07-01 10:21:17 帮助过:8人阅读
HikariCP在github上的地址:https://github.com/brettwooldridge/HikariCP
下面是2张HikariCP和其他连接池组件的性能比较图片:
在其网站上可以看到详细的使用文档,下面是常规的使用方法:
import java.sql.Connection;
import java.sql.SQLException;
import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;
/**
* HikariCP使用
* @author CoolKing
*
*/
public class DataSource {
private HikariDataSource ds;
/**
* 初始化连接池
* @param minimum
* @param Maximum
*/
public void init(int minimum,int Maximum){
//连接池配置
HikariConfig config = new HikariConfig();
config.setDriverClassName("com.mysql.jdbc.Driver");
config.setJdbcUrl("jdbc:mysql://127.0.0.1:3306/testdb?user=root&password=123456&useUnicode=true&characterEncoding=utf8");
config.addDataSourceProperty("cachePrepStmts", true);
config.addDataSourceProperty("prepStmtCacheSize", 500);
config.addDataSourceProperty("prepStmtCacheSqlLimit", 2048);
config.setConnectionTestQuery("SELECT 1");
config.setAutoCommit(true);
//池中最小空闲链接数量
config.setMinimumIdle(minimum);
//池中最大链接数量
config.setMaximumPoolSize(Maximum);
ds = new HikariDataSource(config);
}
/**
* 销毁连接池
*/
public void shutdown(){
ds.shutdown();
}
/**
* 从连接池中获取链接
* @return
*/
public Connection getConnection(){
try {
return ds.getConnection();
} catch (SQLException e) {
e.printStackTrace();
ds.resumePool();
return null;
}
}
public static void main(String[] args) throws SQLException {
DataSource ds = new DataSource();
ds.init(10, 50);
Connection conn = ds.getConnection();
//......
//最后关闭链接
conn.close();
}
}
另外,HikariCP需要依赖下面几个jar
slf4j-api-1.7.12.jar
metrics-core-3.0.2.jar
metrics-healthchecks-3.1.2.jar
javassist-3.19.0-GA.jar
HikariCP-2.3.5.jar
若使用MySQL则还需要mysql-connector-java-5.0.8-bin.jar
以上使用HikariCP需要的jar可以到http://download.csdn.net/detail/abc_key/8790543这个地址下载
号称性能最好的JDBC连接池:HikariCP
标签:hikaricp hikaricp使用