zoukankan      html  css  js  c++  java
  • 一个数据源demo

    前言

    我们重复造轮子,不是为了证明我们比那些造轮子的人牛逼,而是明白那些造轮子的人有多牛逼。

    JDBC介绍

    在JDBC中,我们可以通过DriverManager.getConnection()创建(而不是获取)一个Connection,在完成CRUD之后,再去销毁该Connection。在并发量不高的情况下,创建销毁Connection所花费的时间和资源是可以接受,但是随着并发量的提高,频繁的创建销毁Connection所付出的性能代价太大了,因此在创建一个Connection后能够可以多次使用成了一个很好的选择。在JDBC规范中,通过实现java.sql.Datasource接口,可以屏蔽数据库、操作系统的差异,实现Connection的复用。

    常用开源数据源框架介绍

    目前,我们常用的数据源框架主要有dbcp2、tomcat-jdbc,c3p0,druid、hikariCP:

    1. dbcp2: 由Apache开发的一款优秀数据源;
    2. tomcat-jdbc: tomcat自带的JDBC连接池,是dbcp2的一种替换或备选方案;
    3. c3p0: 一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展,github地址
    4. druid: 阿里出品的一款数据源框架,号称Java语言中最好的数据库连接池,能够提供强大的监控和扩展。
    5. hikariCP: 号称史上最快的数据源,Spring Boot2.0默认的数据源

    Apache Commons Pool2

    Apache Commons Pool2是Apache出品的一套对象池的开源库,提供课一些Pool接口和辅助实现Pool接口的实现。

    PooledObjectFactory

    PooledObjectFactory提供一个管理对象的通用工厂:

    public interface PooledObjectFactory<T> {
       PooledObject<T> makeObject();
       void activateObject(PooledObject<T> obj);
       void passivateObject(PooledObject<T> obj);
       boolean validateObject(PooledObject<T> obj);
       void destroyObject(PooledObject<T> obj);
    }
    

    Apache Commons Pool2提供一个抽象的PooledObjectFactory实现: BasePooledObjectFactory,我们需要实现create和wrap这两个方法。

    GenericObjectPool

    GenericObjectPool 提供了一个简单的、可扩展的Pool实现

    Guobin DataSource

    Guobin是基于Apache Commons Pool2的一个数据源Demo,使用示例:

    public class TestGuobinDataSource {
    
        private static final String DRIVER = "com.mysql.jdbc.Driver";
        private static final String URL  =  "jdbc:mysql://127.0.0.1:3306/world?characterEncoding=utf8&useSSL=false&serverTimezone=GMT%2B8";
        private static final String USERNAME = "root";
        private static final String PASSWORD = "267552";
    
        private static DataSource ds;
    
        @BeforeClass
        public static void initDataSource() {
            ds = GuobinDataSourceBuilder.buildSimpleDataSource(DRIVER, URL, USERNAME, PASSWORD);
        }
    
        @Test
        public void testGetConnection() throws SQLException {
            Assert.assertNotNull(ds.getConnection());
        }
    }
    
  • 相关阅读:
    做汉堡
    第三次作业:五章感想与问题
    第二次作业:结对练习
    自己要的东西
    存在不知道是什么问题的程序
    第一个Sprint冲刺第二天
    第一个Sprint冲刺第一天
    第三个Sprint完结工作 用场景来规划测试工作.
    beta 阶段的 postmortem 报告
    重新评估团队贡献分
  • 原文地址:https://www.cnblogs.com/xiao2/p/9201087.html
Copyright © 2011-2022 走看看