1. 数据库连接池 是什么?
程序连数据库,建连接很慢、很耗资源。
连接池 = 提前开好一堆数据库连接,放在池子里循环复用
- 要查数据 → 从池子里拿一个现成连接
- 用完 → 不关闭,放回池子
避免:每次都新建、销毁,卡死系统。
2. 最大连接数 / 最大会话数 (max 连接)
含义:
数据库最多允许「同时多少个人一起连库」
举例:
最大连接数 = 50
意思:
- 最多 50 个连接同时干活
- 第51个请求进来 → 排队 / 报错 / 拒绝连接
作用
防止几万请求瞬间打爆数据库,限流保命。
3. SQL 查询超时时间 (执行超时)
含义:
一条SQL允许「最多跑多久」
比如设置:10秒
- 正常SQL 0.1秒跑完,没事
- 烂SQL、全表扫描、卡死查询,跑到第10秒
👉 自动强制终止、报错,防止拖垮整个库
重点:
管的是 SQL执行的时间
4. 连接等待超时 (拿连接超时)
含义:
程序去连接池"借一个数据库连接",最多等多久
举例:
连接池满了(30个连接全在用)
新请求要拿连接,排队等:
- 设置等待超时 3秒
- 3秒内还拿不到空闲连接 → 直接报错:获取连接超时
重点:
管的是 等待拿连接的排队时间
和SQL执行快慢没关系
极简 4 句话总结(背下来就行)
- 连接池:复用数据库连接,省性能、提速
- 最大连接数:数据库最多同时扛多少并发
- SQL查询超时:一条SQL最多允许跑多久
- 连接等待超时:拿不到连接时,最多排队等多久
最容易混淆对比
- 拿不到连接、系统爆满 → 是连接等待超时
- 查出不来、SQL卡死 → 是SQL查询超时