为什么建立数据库连接耗时?究竟耗时多久?

数据库连接从连接池中取这已经是大家的共识了,因为频繁的建立或者关闭连接代价太大,那么代价究竟有多大?

我们先准备一个简单的数据库连接代码段

java 复制代码
public static void main(String[] args) throws ClassNotFoundException, SQLException, InterruptedException {
        Class.forName("com.mysql.jdbc.Driver");
        String name = "m_test";
        String password = "m_test";
        String url = "jdbc:mysql://xxxxxx:1234/test"; //脱敏处理
        Connection conn = DriverManager.getConnection(url, name, password);
        conn.close();
    }

然后打开抓包过滤器,分别过滤src和dst是目标数据库地址的网络请求

前面是TCP的三次握手,后面是四次挥手(少了一次,因为服务器的套接字端口已经关了,不会给客户端发请求了,所以没截取到)

详见TCP三次握手、四次分手

我们再看耗时-0.190908s,也就是190ms

除了部分慢sql,一个普通的sql一般最多也就几十毫秒,不会高于100ms

这也就是说,如果不使用连接池,那么每个请求平均多200ms的耗时

一般用户对接口的容忍度也才200ms

如果一个日请求量为10w的系统,那么会平白无故多出四五个小时的耗时,离离原上普了可以说。

相关推荐
炸炸鱼.1 小时前
PostgreSQL 日常维护速查手册
数据库·oracle
014-code2 小时前
MySQL 常用业务 SQL
数据库·sql·mysql
知识分享小能手2 小时前
MongoDB入门学习教程,从入门到精通,MongoDB的选择片键 - 完整知识点(16)
数据库·学习·mongodb
知识分享小能手2 小时前
MongoDB入门学习教程,从入门到精通,MongoDB分片配置完全指南(15)
数据库·学习·mongodb
y = xⁿ2 小时前
【MySQL】数据库的脏读,不可重复读和幻读,覆盖索引是什么,索引类型有哪些
数据库·mysql
小冷coding2 小时前
【面试】结合项目整理的场景面试题,覆盖 Java 基础、锁、多线程、数据库、分布式锁 / 事务、消息中间件等核心维度
java·数据库·面试
kcuwu.2 小时前
Python 正则表达式从入门到实战
数据库·python·正则表达式
卓怡学长2 小时前
m319个人网站的设计与实现
java·数据库·spring·tomcat·maven·intellij-idea
羊小蜜.3 小时前
Mysql 07: 正则表达式查询(REGEXP)全解
数据库·mysql·正则表达式