数据库连接池XDCPool使用详解

在实际应用开发中,特别是在WEB应用系统中,如果JSP、Servlet或EJB使用JDBC直接访问数据库中的数据,每一次数据访问请求都必须经历建立数据库连接、打开数据库、存取数据和关闭数据库连接等步骤,而连接并打开数据库是一件既消耗资源又费时的工作,如果频繁发生这种数据库操作,系统的性能必然会急剧下降,甚至会导致系统崩溃。数据库连接池技术是解决这个问题最常用的方法。

数据库连接池XDCPool对连接提供了四种不同模式的管理,对于不同的访问量我们可以选择不同的管理模式,并且自动回收连接,我们先看下如何使用。

XDCPool使用起来非常简单,几乎零配置,看代码:

Deploy mDeploy = new Deploy()
                .setUrl("jdbc:mysql://127.0.0.1") 
                .setUser("root")
                .setPassword("root")
                //DriverClassName.MySQL是加载MySql的驱动字符串,当然我们也可以替换为“com.mysql.jdbc.Driver”
                .setDriverClassName(DriverClassName.MySQL)
                //设置缓存连接的数量
                .setCacheSize(10)
                //设置最大新建连接的数量
                .setNewMaxSize(500)
                //是否打印日志
                .setCloseLog(true);
XDCPool.init(mDeploy);

这就完成初始化了(初始化只需一次),通过链式调用进行配置,是不是很简单呢。

XDCPool为我们提供了简单的操作数据库的方法,分别是:

//查询操作
XDCPool.delete(String sql,String[] indexs);
//更新操作
XDCPool.update(String sql,String[] indexs);
//查询操作
XDCPool.select(String sql,String[] indexs);
//插入操作
XDCPool.insert(String sql,String[] indexs);

使用如下:

//删除操作
XDCPool.delete("DELETE FROM ? WHERE id=?",new String[]{"student","1"});
//更新操作
XDCPool.update("UPDATE ? SET name = ? WHERE id = ?",new String[]{"student","张三","1"});
//查询操作
XDCPool.select("SELECT * FROM student",null);
//插入操作
XDCPool.insert("INSERT INTO student VALUES (?,?)",new String[]{"1","张三"});

当我们对数据库进行增删改查时尽量使用XDCPool为我们提供的这四种方法,因为它会自动回收我们的连接,也不需要我们手动进行关闭。

如果说我们想自己拿到连接进行处理,该怎么办呢?我们可以通过调用下面的方法拿到连接(注意使用完之后,务必调用XDCPool.release(mConnection)进行手动回收):

Connection mConnection = XDCPool.getConnection();

如果你想随时查看连接池中的连接的数量,我们可以调用下面的方法:

//得到缓存池中的数量
XDCPool.getCacheConnectionCount();
//得到当前新建的连接的数量
XDCPool.getNewConnectionCount();

当然还有关闭连接池的方法:

XDCPool.closeConnectionPool();

上面说过XDCPool有四种模式可以选择,这里怎么没有配置呢?其实模式的配备不需要我们手动设置,XDCPool会根据我们setCacheSize()方法和setNewMaxSize()自动匹配。
1、设置了缓存数量和最大新建连接数量:那么XDCPool在初始化时会新建我们指定的连接数量,当我们需要使用连接时随时可以拿到连接。当程序遇到高并发时,它会快速新建大量新的连接应付高并发,当然这是有限制的,新建的连接数受我们指定最大新建连接数的制约。
2、设置了缓存数量但没有设置最大新建连接数量:那么XDCPool在初始化时会新建我们指定的连接数量,并定期会检查连接是否可用,当我们的程序遇到高并发时,它会快速创建大量新的连接应付高并发(无限制)。当我们的程序恢复正常时,XDCPool保留指定的连接数量,多余的连接会替我们关闭。
3、设置了最大新建连接数量但没有设置缓存数量:那么XDCPool在初始化时不创建连接,当程序需要使用连接时会及时创建连接,连接使用完毕并不会被XDCPool及时关闭掉,它会保留一分钟,在这一分钟内,如果需要再次连接数据库,那么这个连接就会被复用。当我们的程序遇到高并发时,和模式1相同,它会快速创建大量新的连接应付高并发,但受我们指定最大新建连接数的制约。
4、没有设置最大新建连接数量和缓存的数量:那么XDCPool在初始化时不创建连接,当程序需要使用连接时会及时创建连接,连接使用完毕并不会被XDCPool及时关闭掉,它会保留一分钟,在这一分钟内,如果需要再次连接数据库,那么这个连接就会被复用。当我们的程序遇到高并发时,它会快速创建大量新的连接应付高并发(无限制)。

XDCPool地址:https://github.com/519401502/XDCPool
直接下载XDCPool.jar包即可,欢迎start😊

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,026评论 19 139
  • 最原始的数据库连接就是我们打开一个连接,使用过后再关闭该链接来释放资源。频繁的新建打开再关闭连接对jvm和数据库都...
    野柳阅读 6,456评论 1 11
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,765评论 25 709
  • 放了个假,断更了十几天,再次重新开始。 这是目前看到对知行合一解读最深刻的一次。不断的提高自己的认知,才能做出正确...
    刘子逸阅读 215评论 0 0
  • 是因为到了这个年纪,才有有了太多的脾气? 还是因为这颗心孤独又傲气,无法融入无法靠近. 我是一个奇怪的人,曾...
    nothingli阅读 206评论 0 0