asyncpg/fastapi创建的连接数超过了连接池的限制。
创始人
2024-09-21 08:00:41
0

可以通过设置 max_size 参数来控制连接池的大小,避免创建过多的连接。同时,还可以使用 await connection.release() 来释放连接,以便其他请求可以获取连接。

示例代码:

import asyncio
import asyncpg
from fastapi import FastAPI

app = FastAPI()
dsn = "postgresql://user:password@localhost/mydatabase"

async def connect_to_db(app):
    app.pool = await asyncpg.create_pool(dsn=dsn, max_size=10)

@app.on_event("startup")
async def startup():
    await connect_to_db(app)

@app.on_event("shutdown")
async def shutdown():
    await app.pool.close()

@app.get("/")
async def root():
    async with app.pool.acquire() as connection:
        # Use connection
        pass
        await connection.release() # 释放连接

在上面的代码中,max_size 参数设置了连接池的最大大小为 10,确保不会创建超过 10 个连接。同时,在 root() 函数中,使用 async with app.pool.acquire() as connection: 来获取连接,并在使用后使用 await connection.release() 来释放连接。这样可以确保每次只使用一个连接,并避免创建过多的连接。

相关内容

热门资讯

透视教学"pokem... 这是一款非常优秀的pokemmo辅助器手机版下载 ia辅助检测软件,能够让你了解到pokemmo辅助...
透视玄学"wepok... 透视玄学"wepoker免费脚本弱密码"详细辅助我来教教你(科技辅助器技巧)准备好在wepoker免...
透视智能ai"hhp... 透视智能ai"hhpoker到底可以作弊吗"详细辅助AI教程(黑侠辅助器透明);hhpoker到底可...
透视新版"wepok... 透视新版"wepoker免费辅助器"详细辅助科技教程(可以透视码辅助)1、很好的工具软件,可以解锁游...
透视教学"wepok... 1、透视教学"wepoker透视脚本"详细辅助2025版教程(透视破解版透明);详细教程。2、wep...
透视数据"hhpok... 透视数据"hhpoker必备开挂"详细辅助细节方法(透视脚本安卓方法)关于hhpoker必备开挂机制...
透视安装"wepok... 透视安装"wepoker怎么挂底牌"详细辅助AI教程(轻量版透视透视);致您一封信;亲爱wepoke...
透视ai"智星德州插... 透视ai"智星德州插件怎么下载"详细辅助2025新版教程(挂辅助)准备好在智星德州插件怎么下载 ia...
透视透视"wepok... 1、透视透视"wepoker辅助透视软件"详细辅助力荐教程(免费脚本神器);详细教程。2、wepok...
透视计算"哈糖大菠萝... 透视计算"哈糖大菠萝破解器"详细辅助解密教程(正规技巧);亲真的是有正版授权,小编(透视辅助软件透明...