Python&Flask 使用 DBUtils 创建通用连接池

DBUtils 是 Python 中一个轻量级且高效的数据库连接池工具,支持多种数据库

1、安装

首先,需要确保安装了 DBUtils 库以及你的数据库驱动,比如 pymysql

bash 复制代码
pip install DBUtils pymysql

2、创建连接池

以下是使用 DBUtils 创建连接池的基本步骤和示例代码:

python 复制代码
from DBUtils.PooledDB import PooledDB
import pymysql

# 配置数据库连接参数
db_config = {
    'host': 'localhost',      # 数据库主机
    'user': 'your_username',  # 数据库用户名
    'password': 'your_password',  # 数据库密码
    'database': 'your_db',    # 数据库名称
    'charset': 'utf8mb4'      # 字符编码
}

# 创建连接池
pool = PooledDB(
    creator=pymysql,          # 使用 pymysql 驱动
    maxconnections=5,         # 最大连接数
    mincached=2,              # 初始化时的最小连接数
    maxcached=5,              # 连接池中最大的空闲连接数
    blocking=True,            # 当连接数耗尽时是否阻塞等待
    **db_config               # 数据库连接配置参数
)
2.1连接池配置参数详解
参数 说明 推荐值 必填
creator 数据库驱动模块 pymysql/psycopg2等
maxconnections 最大连接数 10-100(根据服务器配置)
mincached 初始空闲连接数 2-5
maxcached 最大空闲连接数 5-10
maxshared 最大共享连接数 3-5
blocking 连接池满时是否阻塞 True(推荐)
ping 连接检查方式 0(不检查)/1(使用前检查)/2/3/4/7
setsession 初始化SQL命令 ['SET NAMES utf8mb4']
reset 连接返回池时是否重置 True/False

3、使用连接池

python 复制代码
# 使用连接池获取连接
def perform_query():
    conn = pool.connection()  # 取连接
    try:
        cursor = conn.cursor()
        cursor.execute("SELECT * FROM your_table")  # 执行查询
        result = cursor.fetchall()
        print(result)
    finally:
        cursor.close()
        conn.close()  # 将连接归还连接池

# 执行数据库查询
perform_query()

4、Flask集成示例:

python 复制代码
from flask import Flask, g
# g是 Flask 提供的请求级别的"临时全局存储",特别适合存储数据库连接、用户认证信息等需要在同一个请求的不同函数间共享的数据。

app = Flask(__name__)

# 初始化连接池
mysql_pool = PooledDB(
    creator=pymysql,
    maxconnections=20,
    host='localhost',
    user='flask_user',
    password='password',
    database='flask_db'
)

# 获取数据库连接
def get_db():
    if 'db' not in g:
        g.db = mysql_pool.connection()
    return g.db

# 关闭数据库连接
@app.teardown_appcontext
def close_db(error):
    db = g.pop('db', None)
    if db is not None:
        db.close()

# 路由示例
@app.route('/users/<int:user_id>')
def get_user(user_id):
    db = get_db()
    with db.cursor() as cursor:
        cursor.execute("SELECT * FROM users WHERE id = %s", (user_id,))
        user = cursor.fetchone()
    return {'user': user} if user else (
相关推荐
海棠AI实验室3 小时前
专栏导读:你将交付什么、如何学、如何做作品集
python·数据挖掘
m0_613607013 小时前
小土堆-P3-笔记
pytorch·python·深度学习
rgeshfgreh3 小时前
Python高效开发:标准库与第三方库实战指南
python
十五年专注C++开发3 小时前
VS2019编译的C++程序,在win10正常运行,在win7上Debug正常运行,Release运行报错0xC0000005,进不了main函数
开发语言·c++·报错c0x0000005
一条咸鱼_SaltyFish3 小时前
[Day13] 微服务架构下的共享基础库设计:contract-common 模块实践
开发语言·人工智能·微服务·云原生·架构·ai编程
隐退山林3 小时前
JavaEE:多线程初阶(一)
java·开发语言·jvm
虎冯河3 小时前
阿里云 + 宝塔面板环境Python 项目从 0 到 1 部署全流
python·阿里云·云计算
C_心欲无痕3 小时前
ts - 模板字面量类型与 `keyof` 的魔法组合:`keyof T & `on${string}`使用
linux·运维·开发语言·前端·ubuntu·typescript
最贪吃的虎3 小时前
Redis其实并不是线程安全的
java·开发语言·数据库·redis·后端·缓存·lua
鹿衔`3 小时前
PySpark 大规模造数任务优化与实施总结文档
python·pyspark