Druid连接池(无框架)
关于连接池有不少技术可以用,例如c3p0,druid等等,因为druid有监控平台,性能在同类产品中算top0的。所以我采用的事druid连接池。
首先熟悉一个技术,我们要搞明白,为什么要用他, 他能帮我们解决什么问题?
如果不使用连接池会出现的情况:
a.占用服务器的内存资源
b.导致服务器的速度非常慢
1.准备
下载druid1.9的jar包和对应数据库的驱动包。
https://mvnrepository.com/artifact/com.alibaba/druid/1.0.9
2.代码
2.1db.properties
- driverClassName=net.sourceforge.jtds.jdbc.Driver
- url=jdbc:jtds:sqlserver:/XXXXX:1433/szqxjimg;SelectMethod=Cursor;DatabaseName=szqxjimg
- username=sa
- password=123456
- # 配置参数,让ConfigFilter解密密码
- #connectionProperties=config.decrypt=true;config.decrypt.key=xxxx
- # 监控统计拦截的filters
- filters=stat
- # 初始化时建立物理连接的个数,初始化发生在显示调用init方法,或者第一次getConnection时
- initialSize=1
- # 最大连接池数量
- maxActive=10
- # 最小连接池数量
- minIdle:1
- # 获取连接等待超时的时间,单位毫秒
- maxWait=60000
- # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
- # 有两个含义:1) Destroy线程会检测连接的间隔时间 2) testWhileIdle的判断依据,详细看testWhileIdle属性的说明
- timeBetweenEvictionRunsMillis=60000
- # 一个连接在池中最小生存的时间,单位是毫秒
- minEvictableIdleTimeMillis=300000
- # 用来检测连接是否有效
- validationQuery=SELECT 1
- # 申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效
- testWhileIdle=true
- # 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能
- testOnBorrow=false
- # 归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能
- testOnReturn=false
- # 是否缓存preparedStatement,也就是PSCache
- poolPreparedStatements=true
- maxPoolPreparedStatementPerConnectionSize=200
2.2代码
- package com.qihui.qxj.utils;
- import java.io.InputStream;
- import java.sql.Connection;
- import java.sql.ResultSet;
- import java.sql.SQLException;
- import java.sql.Statement;
- import java.util.Properties;
- import javax.sql.DataSource;
- import com.alibaba.druid.pool.DruidDataSourceFactory;
- import com.qihui.qxj.services.system.Brand;
- public class DruidUtil {
- private static Properties p;
- private static DataSource dataSource;
- static {
- try {
- ClassLoader loader = Thread.currentThread().getContextClassLoader();
- InputStream inputStream = loader.getResourceAsStream("db.properties");
- p = new Properties();
- p.load(inputStream);
- // 通过工厂类获取DataSource对象
- dataSource = DruidDataSourceFactory.createDataSource(p);
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- public static Connection getConnection() {
- try {
- return dataSource.getConnection();
- } catch (Exception e) {
- e.printStackTrace();
- }
- return null;
- }
- public static void close(Connection conn, Statement state, ResultSet result) {
- try {
- if (result != null) {
- result.close();
- }
- } catch (SQLException e) {
- e.printStackTrace();
- } finally {
- try {
- if (conn != null) {
- conn.close();
- }
- } catch (SQLException e) {
- e.printStackTrace();
- } finally {
- try {
- if (state != null) {
- state.close();
- }
- } catch (SQLException e) {
- e.printStackTrace();
- }
- }
- }
- }
- public static void main(String[] args) {
- Brand brand = new Brand();
- long startTIme =System.currentTimeMillis();
- for (int i = 0; i < 1000; i++) {
- String selectBrand = brand.getSelectBrand();
- }
- long endTime =System.currentTimeMillis();
- System.out.println(endTime- startTIme);
- }
- }
3.结论
通过多次测试,发现,循环查询1000次,不使用连接池,查询性能为7500ms,使用连接池后,查询速度为1515ms,可以看出查询性能优化勒很多。
Druid连接池(无框架)的更多相关文章
- Druid连接池和springJDbc框架-Java(新手)
Druid连接池: Druid 由阿里提供 安装步骤: 导包 durid1.0.9 jar包 定义配置文件 properties文件 名字任意位置也任意 加载文件 获得数据库连接池对象 通过Durid ...
- spring+mybatis+c3p0数据库连接池或druid连接池使用配置整理
在系统性能优化的时候,或者说在进行代码开发的时候,多数人应该都知道一个很基本的原则,那就是保证功能正常良好的情况下,要尽量减少对数据库的操作. 据我所知,原因大概有这样两个: 一个是,一般情况下系统服 ...
- SpringBoot2.0 基础案例(07):集成Druid连接池,配置监控界面
一.Druid连接池 1.druid简介 Druid连接池是阿里巴巴开源的数据库连接池项目.Druid连接池为监控而生,内置强大的监控功能,监控特性不影响性能.功能强大,能防SQL注入,内置Login ...
- Spring Boot (四): Druid 连接池密码加密与监控
在上一篇文章<Spring Boot (三): ORM 框架 JPA 与连接池 Hikari> 我们介绍了 JPA 与连接池 Hikari 的整合使用,在国内使用比较多的连接池还有一个是阿 ...
- Java开发笔记(一百五十一)Druid连接池的用法
C3P0连接池自诞生以来在Java Web领域反响甚好,业已成为hibenate框架推荐的连接池.谁知人红是非多,C3P0在大型应用场合中暴露了越来越多的局限性,包括但不限于下列几点:1.C3P0管理 ...
- druid连接池获取不到连接的一种情况
数据源一开始配置: jdbc.initialSize=1jdbc.minIdle=1jdbc.maxActive=5 程序运行一段时间后,执行查询抛如下异常: exception=org.mybati ...
- 使用druid连接池的超时回收机制排查连接泄露问题
在工程中使用了druid连接池,运行一段时间后系统出现异常: Caused by: org.springframework.jdbc.CannotGetJdbcConnectionException: ...
- Druid连接池
Druid 连接池简介 Druid首先是一个数据库连接池.Druid是目前最好的数据库连接池,在功能.性能.扩展性方面,都超过其他数据库连接池,包括DBCP.C3P0.BoneCP.Proxool.J ...
- 使用MyBatis集成阿里巴巴druid连接池(不使用spring)
在工作中发现mybatis默认的连接池POOLED,运行时间长了会报莫名其妙的连接失败错误.因此采用阿里巴巴的Druid数据源(码云链接 ,中文文档链接). mybatis更多数据源参考博客链接 . ...
随机推荐
- go语言入门(3)运算符及流程控制
1,运算符 算数运算符:+ - * / % ++ -- 关系运算符:== != < > <= >== 逻辑运算符:按位与 ...
- 能当壁纸用的Git常用命令速查表
使用Microsoft Office 2016手工绘制. 链接: https://pan.baidu.com/s/18KsH-u5T2iSTHaXd6iQWGA 提取码: w8da 复制这段内容后打开 ...
- 第八章·Logstash深入-通过TCP/UDP收集日志
1.收集TCP/UDP日志 通过logstash的tcp/udp插件收集日志,通常用于在向elasticsearch日志补录丢失的部分日志,可以将丢失的日志通过一个TCP端口直接写入到elastics ...
- kubernetes资源清单之DaemonSet
什么是 DaemonSet? DaemonSet 确保全部(或者某些)节点上运行一个 Pod 的副本.当有节点加入集群时,也会为他们新增一个 Pod . 当有节点从集群移除时,这些 Pod 也会被回收 ...
- main特别之处
//package new_Object; public class Main{ public static void main(String[] args) { System.out.println ...
- python常用模块:模块练习
今日作业: 1.简述 什么是模块 模块就将一些函数功能封装在一个文件内,以‘文件名.py’命名,以“import 文件名”方式调用 模块有哪些来源 自定义.内置.DLL编译器.包模块的格式要求有哪些 ...
- sql like 拼接字符串模糊查询
这种分割的值大家常用,如果要用like 来查询包含2,这个值的数据有哪些,这个怎么查? like '%2%' ????,这是不行的如果是 44,125,687 同样可以查出来,那么就想到通配符, l ...
- DP tricks and experiences
[LeetCode] 关于动态规划的经验与技巧. 很多时候多分配一位空间是为了递推的方便,例如前推两位. 辅助数组的索引,用到的可能是 1 — N,或者是 0 — N-1. 具体要看清 f[i] 每一 ...
- for(auto count:counts)
c++中for(auto count : counts) 这是C++11中的语法,即:Range-based for loop.其中counts应满足:begin(counts), end(count ...
- 第二章 Vue快速入门--7 讲解v-cloak、v-text、v-html的基本使用
7 讲解v-cloak.v-text.v-html的基本使用 <!DOCTYPE html> <html lang="en"> <head> & ...