瞎j8封装第二版之数据库连接池
写得很蛋疼,本来想支持多线程的,奈何对多线程和连接池理解着实太菜;
所以,起码是能拿到连接了。。。
但是还是不太懂这个连接池
我也是半抄别人的,以后再搞一搞这个吧。
先是配置文件 理想是很丰满的,奈何现实。。。
jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&useSSL=true jdbc.username=root jdbc.password=yck940522 #最小连接数 jdbc.minSize= #最大连接数 jdbc.maxSize= #初始化连接数 jdbc.initSize= #重试次数 jdbc.tryTimes= #延迟时间 jdbc.delay= jdbc.maxActiveSize= jdbc.timeOut= jdbc.check = true jdbc.checkTime =
配了那么多参数,很多都没用上。。唉,还是太菜;
package jdbc; import java.io.IOException; import java.io.InputStream; import java.util.Properties; public class DataBase { private static String username; private static String password; private static String url; private static String driver; private static Integer minSize; private static Integer maxSize; private static Integer initSize; private static Integer maxActiveSize; private static Integer tryTimes; private static Long delay; private static Long timeOut; private static Boolean checked; private static Long checkTime; private static DataBase instance; private DataBase(){ InputStream in = DataBase.class.getClassLoader().getResourceAsStream("jdbc.properties"); Properties p = new Properties(); try { p.load(in); username = p.getProperty("jdbc.username"); password = p.getProperty("jdbc.password"); url = p.getProperty("jdbc.url"); driver = p.getProperty("jdbc.driver"); minSize = Integer.valueOf(p.getProperty("jdbc.minSize","3")); maxSize = Integer.valueOf(p.getProperty("jdbc.maxSize","20")); initSize = Integer.valueOf(p.getProperty("jdbc.initSize","5")); maxActiveSize = Integer.valueOf(p.getProperty("jdbc.maxActiveSize","100")); tryTimes =Integer.valueOf(p.getProperty("jdbc.tryTimes","2")); delay = Long.valueOf(p.getProperty("jdbc.delay","1000")); timeOut = Long.valueOf(p.getProperty("jdbc.timeOut","1200000")); checked = Boolean.valueOf(p.getProperty("jdbc.check","false")); checkTime = Long.valueOf(p.getProperty("jdbc.checkTime","30000")); } catch (IOException e) { e.printStackTrace(); }finally { if(in != null){ try { in.close(); } catch (IOException e) { e.printStackTrace(); } } } } public static DataBase getInstance(){ if(instance == null){ synchronized (DataBase.class){ if(instance == null){ instance = new DataBase(); } } } return instance; } public String getUsername() { return username; } public String getPassword() { return password; } public String getUrl() { return url; } public String getDriver() { return driver; } public Integer getMinSize() { return minSize; } public Integer getMaxSize() { return maxSize; } public Integer getInitSize() { return initSize; } public Integer getMaxActiveSize() { return maxActiveSize; } public Integer getTryTimes() { return tryTimes; } public Long getDelay() { return delay; } public Long getTimeOut() { return timeOut; } public Boolean getChecked() { return checked; } public Long getCheckTime() { return checkTime; } }
对单例也不太懂,瞎写,有经验的大佬指正一下啊
package jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import java.util.List; import java.util.Timer; import java.util.TimerTask; import java.util.Vector; import java.util.concurrent.atomic.AtomicInteger; public class ConnectionPool{ private static final Long lazyTime = 30000L; private DataBase dataBase; private AtomicInteger totalSize = new AtomicInteger(0); private List<Connection> freeConnections = new Vector<Connection>(); private ThreadLocal<Connection> threadLocal = new ThreadLocal<Connection>(); private static ConnectionPool instance; private ConnectionPool(){ this.dataBase = DataBase.getInstance(); init(); } public static ConnectionPool getInstance(){ if(instance == null){ synchronized (ConnectionPool.class){ if(instance == null){ instance = new ConnectionPool(); } } } return instance; } private void init(){ try { Class.forName(dataBase.getDriver()); for(int i=0;i<dataBase.getInitSize();i++){ Connection connection = createConnection(); freeConnections.add(connection); } } catch (ClassNotFoundException e) { e.printStackTrace(); } } private synchronized Connection createConnection(){ try { Class.forName(dataBase.getDriver()); Connection conn= DriverManager.getConnection(dataBase.getUrl(),dataBase.getUsername(),dataBase.getPassword()); totalSize.incrementAndGet(); return conn; } catch (SQLException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } return null; } private synchronized Connection getConnection() { Connection conn= null; try { if(totalSize.get() < dataBase.getMaxSize()){ if(freeConnections.size()>0){ conn = freeConnections.get(0); if(conn != null){ threadLocal.set(conn); } freeConnections.remove(0); }else { conn = createConnection(); } }else { wait(dataBase.getDelay()); conn = getConnection(); } } catch (InterruptedException e) { e.printStackTrace(); } return conn; } private boolean isValid(Connection conn){ try { if(conn == null || conn.isClosed()){ return false; } } catch (SQLException e) { e.printStackTrace(); } return true; } public synchronized Connection getCurrentConnection() { Connection conn = threadLocal.get(); if(!isValid(conn)){ return getConnection(); } return conn; } public void checkPool() { if(dataBase.getChecked()){ new Timer().schedule(new TimerTask() { @Override public void run() { System.out.println("空线池连接数:"+freeConnections.size()); System.out.println("总的连接数:"+totalSize.get()); } }, lazyTime, dataBase.getCheckTime()); } } }
这个连接池我就不做什么说明了。。。自己只能理解最简单的。。。简单的说就是先初始化一部分连接放在一个list里,要用的时候就去取,如果没有超过上限也不用close了。。但是我一直没搞明白怎么去判断它空闲了多长时间然后close掉。。。所以很多也没实现。
大王让我写代码
2017-12-30
瞎j8封装第二版之数据库连接池的更多相关文章
- 瞎j8封装第二版之数据层的封装
看了以前写的代码,对就是下面这个 手把手封装数据层之DataUtil数据库操作的封装 觉得以前写的代码好烂啊!!!,重新理了一下思路,写得更规范和简练,应该效率也会高很多,用了一下下午写的连接池(半废 ...
- 瞎j8封装第二版之用xml文件来代理dao接口
也是重新整理了之前的那篇 模仿Mybatis用map per.xml实现Dao层接口的功能 话不多说直接上代码 首先是结构 依赖pom.xml <?xml version="1.0&q ...
- 一只菜鸟的瞎J8封装系列的目录
因为这是一个系列...也就是我们所说的依赖关系.后面很多方法都是基于我前面封装的工具来进行的,所以我列一个目录供大家参考... 一只菜鸟的瞎J8封装系列 一.手把手封装数据层之DButil数据库连接 ...
- 计算器-- 利用re模块 利用函数封装 第二版
import re remove_parentheses = re.compile('\([^()]+\)') def Remove_Parentheses(obj, s): # 找到内层的括号并且返 ...
- Java数据库连接池封装与用法
Java数据库连接池封装与用法 修改于抄袭版本,那货写的有点BUG,两个类,一个用法 ConnectionPool类: package com.vl.sql; import java.sql.Conn ...
- 【数据库开发】如何创建MySQL数据库连接池(一个基于libmysql的MySQL数据库连接池示例(C/C++版))
http://blog.csdn.net/horace20/article/details/8087557 1. 一般架构说明 图 1 架构层次图 一般应用系统数据库访问模块可大致分为两层,一层 ...
- 关于jdbc和数据库连接池的关系(不是封装的关系)
你都说是数据库连接池了.那就是连接数据库用的.JDBC是java封装的对数据库的操作.当然你可以自己进一步封装.数据库连接池是JDBC使用的前提,如果连数据库连接池都没连上,JDBC的操作就谈不上了. ...
- java 数据库连接池 Oracle版
首先应加入连接池和数据库连接的配置文件:数据库连接包:ojdbc6.jar数据库连接池包:commons-pool2-2.2.jar commons-dbc ...
- mongodb数据库连接池(java版)
mongodb数据库接口的设计 package storm.db; import java.util.ArrayList; import com.mongodb.DB; import com.mong ...
随机推荐
- C++雾中风景3:const用法的小结
const作为C与C++共有的关键字,很多使用的方式大同小异.但由于C++是一门面向对象的语言,在类和对象中有更多的使用规则.之前学习C语言的时候就被const这个关键字搅得焦头烂额,正巧也借这篇文章 ...
- 作为函数的mixin
作为函数的mixin 在一个 mixin 内部定义的变量或 mixin,都调用者可见,因此,它们可以作为它的返回值.如,以下Less代码: .count(@x, @y) { @sum:(@x ...
- CentOS7 64位 安装MySQL5.7
安装环境:CentOS7 64位 MINI版,安装MySQL5.7 1.配置YUM源 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo ...
- Shell编程基础篇
1.1 前言 1.1.1 为什么学Shell Shell脚本语言是实现Linux/UNIX系统管理及自动化运维所必备的重要工具, Linux/UNIX系统的底层及基础应用软件的核心大都涉及Shell脚 ...
- python 抓取金融数据,pandas进行数据分析并可视化系列 (一)
终于盼来了不是前言部分的前言,相当于杂谈,算得上闲扯,我觉得很多东西都是在闲扯中感悟的,比如需求这东西,一个人只有跟自己沟通好了,总结出某些东西了,才能更好的和别人去聊,去说. 今天这篇写的是明白需求 ...
- JAVA提高十九:WeakHashMap&EnumMap&LinkedHashMap&LinkedHashSet深入分析
因为最近工作太忙了,连续的晚上支撑和上班,因此没有精力来写下这篇博客,今天上午正好有一点空,因此来复习一下不太常用的集合体系大家族中的几个类:WeakHashMap&EnumMap&L ...
- RGBA 和 opacity的区别
两者都可以设置透明度 区别 RGBA 只影响当前元素 opacity 后代会继承该css 值,暂时还没有办法清除该css 在线演示
- KMP算法求next数组
next数组的求解方法是:第一位的next值为0,第二位的next值为1.后面求解每一位的next值时,根据前一位进行比较.首先将前一位与其next值对应的内容进行比较,如果相等,则该位的next值就 ...
- php+jQuery+Mysql找回密码----ThinkPHP
最近用ThinkPHP做了一个邮箱找回密码功能,在遭遇了N个bug之后终于做成了,下面分享一下邮箱找回密码功能的实现: 邮箱找回密码实际上就是在用户通过验证之后重置密码的过程,一般开发者会在验证用户信 ...
- mybatis中使用if标签比较两个字符串是否相等
<!-- 此处使用if比较是否相等 --> 范例一: <select id="findClientIds" parameterType="map&quo ...