Java Web简明教程–Java篇[11]–数据库连接池

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Java Web简明教程–Java篇[11]–数据库连接池

前面(Java篇[9])演示了两个极端的数据库使用方式:


第一种:每次使用数据库,都建立一个新的连接,使用完毕后关闭连接。这种是非常安全的,因为每次使用的都是新连接互不干扯。缺点是非常浪费时间和资源,要知道建立连接是比较浪费时间的。


第二种,就一个数据库连接,该连接保存在一个静态的对象里面,不管多少次请求都用这个连接来实现。优点是速度快,缺点是不可靠,这个缺点对Web网站来说是致命的。据猫哥了解,不同的数据库驱动对数据库连接的处理方式是不确定的,比如MySQL如果只采用一个数据库连接,那么可能会出现:a此连接长时间不用被收回;b多个同时并发的访问使用此连接,因为MySQL连接是串行执行数据库操作的,所以需要长时间排队。


OK,说白了,第一种就是每次都用新筷子,用完就扔了买新的。第二种就是一共就一双筷子,如果人多就排队使用。


那么数据库连接池是一种什么样的思想呢,其实很简单,就是如果我们常用20双筷子(最大并发量20,最多20人同时访问),我们就设置个20容量的池子。来一个访问就分配一个连接,直到20个都分配完了那就报错。


就这么简单,猫哥简单实现如下(就按20个最大连接实现):


import java.sql.*;
import java.util.LinkedList;
public class MysqlPool {
    //这就是我们的池子,想下为啥用static,为啥用LinkedList
    private static LinkedList pool = new LinkedList(); 
    //池水的深度(哈哈,其实就是最大连接数)
    private static int maxCount=20;
    public static void init(){//初始化,就是让20个连接有意义
      try{
      for(int i=0;i
        MysqlHandler handler=new MysqlHandler();
                Connection connection = handler.buildConnection();//建立连接,并放于池中,不用担心这个连接找不到了,因为已经是池中之物了
                pool.add(connection);
            }
         }catch(Exception e){//此处threw exception更好,为何?
          e.printStackTrace();
         }
    }
    public static Connection getConnecton(){//从池中获取一个连接
      if(pool.size()==0)//分配完了
      {
      return null;//没有连接可用
      }
      else{
      return pool.remove(0);//删除第一个对象并返回
      }
    }
    public static void release(Connection connection){//使用完的归还给池子
        pool.add(connection);
    }
}


import java.sql.*;
public class TestMysql {//测试MysqlHandler类
  public static void main(String[] args)  {
  try {//捕获异常
    long start=System.currentTimeMillis();//产生一个当前的毫秒(自1970年1月1日0时起的毫秒数)
    MysqlPool.init();
    for(int i=0;i<1000;i++){
    testOneTime();
    }
    long end=System.currentTimeMillis();
    System.out.println("\n消耗时间:"+(end-start)+"毫秒");
  } catch (SQLException e) {
    e.printStackTrace();
  }
  }
  //测试一次完整查询
  private static void testOneTime()throws SQLException{//可能会有异常,我们在更广阔的天地捕获之
  Connection conn = MysqlPool.getConnecton();
  Statement stmt = conn.createStatement();
  ResultSet rs = null;
  rs=stmt.executeQuery("select * from student_info");
  rs.close();
  stmt.close();
  MysqlPool.release(conn);//注意Statement和ResultSet是需要释放的,而Connection放在池子里面循环使用,不必释放,为啥呢?因为Connection建立连接太耗时!
  }
}

OK,上面猫哥实现了一个相当简单的池子,但是也够用了,主要是体会池子的思想,还是相当贴近现实啊。


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
12天前
|
消息中间件 Java 数据库
自研Java框架 Sunrays-Framework使用教程「博客之星」
### Sunrays-Framework:助力高效开发的Java微服务框架 **Sunrays-Framework** 是一款基于 Spring Boot 构建的高效微服务开发框架,深度融合了 Spring Cloud 生态中的核心技术组件。它旨在简化数据访问、缓存管理、消息队列、文件存储等常见开发任务,帮助开发者快速构建高质量的企业级应用。 #### 核心功能 - **MyBatis-Plus**:简化数据访问层开发,提供强大的 CRUD 操作和分页功能。 - **Redis**:实现高性能缓存和分布式锁,提升系统响应速度。 - **RabbitMQ**:可靠的消息队列支持,适用于异步
自研Java框架 Sunrays-Framework使用教程「博客之星」
|
14天前
|
SQL Java 关系型数据库
使用 JDBC 实现 Java 数据库操作
JDBC(Java Database Connectivity)是 Java 提供的数据库访问技术,允许通过 SQL 语句与数据库交互。本文详细介绍了 JDBC 的使用方法,包括环境准备、编程步骤和完整示例。
72 7
|
14天前
|
SQL Java 数据库连接
【潜意识Java】MyBatis中的动态SQL灵活、高效的数据库查询以及深度总结
本文详细介绍了MyBatis中的动态SQL功能,涵盖其背景、应用场景及实现方式。
64 6
|
14天前
|
Java 数据库连接 数据处理
探究Java异常处理【保姆级教程】
Java 异常处理是确保程序稳健运行的关键机制。它通过捕获和处理运行时错误,避免程序崩溃。Java 的异常体系以 `Throwable` 为基础,分为 `Error` 和 `Exception`。前者表示严重错误,后者可细分为受检和非受检异常。常见的异常处理方式包括 `try-catch-finally`、`throws` 和 `throw` 关键字。此外,还可以自定义异常类以满足特定需求。最佳实践包括捕获具体异常、合理使用 `finally` 块和谨慎抛出异常。掌握这些技巧能显著提升程序的健壮性和可靠性。
34 4
|
14天前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
29 2
|
14天前
|
存储 移动开发 算法
【潜意识Java】Java基础教程:从零开始的学习之旅
本文介绍了 Java 编程语言的基础知识,涵盖从简介、程序结构到面向对象编程的核心概念。首先,Java 是一种高级、跨平台的面向对象语言,支持“一次编写,到处运行”。接着,文章详细讲解了 Java 程序的基本结构,包括包声明、导入语句、类声明和 main 方法。随后,深入探讨了基础语法,如数据类型、变量、控制结构、方法和数组。此外,还介绍了面向对象编程的关键概念,例如类与对象、继承和多态。最后,针对常见的编程错误提供了调试技巧,并总结了学习 Java 的重要性和方法。适合初学者逐步掌握 Java 编程。
39 1
|
23天前
|
Kubernetes Java 持续交付
小团队 CI/CD 实践:无需运维,Java Web应用的自动化部署
本文介绍如何使用GitHub Actions和阿里云Kubernetes(ACK)实现Java Web应用的自动化部署。通过CI/CD流程,开发人员无需手动处理复杂的运维任务,从而提高效率并减少错误。文中详细讲解了Docker与Kubernetes的概念,并演示了从创建Kubernetes集群、配置容器镜像服务到设置GitHub仓库Secrets及编写GitHub Actions工作流的具体步骤。最终实现了代码提交后自动构建、推送镜像并部署到Kubernetes集群的功能。整个过程不仅简化了部署流程,还确保了应用在不同环境中的稳定运行。
52 9
|
2月前
|
移动开发 前端开发 Java
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
JavaFX是Java的下一代图形用户界面工具包。JavaFX是一组图形和媒体API,我们可以用它们来创建和部署富客户端应用程序。 JavaFX允许开发人员快速构建丰富的跨平台应用程序,允许开发人员在单个编程接口中组合图形,动画和UI控件。本文详细介绍了JavaFx的常见用法,相信读完本教程你一定有所收获!
Java最新图形化界面开发技术——JavaFx教程(含UI控件用法介绍、属性绑定、事件监听、FXML)
|
2月前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
158 26
|
14天前
|
前端开发 Java 开发工具
Git使用教程-将idea本地Java等文件配置到gitte上【保姆级教程】
本内容详细介绍了使用Git进行版本控制的全过程,涵盖从本地仓库创建到远程仓库配置,以及最终推送代码至远程仓库的步骤。
23 0