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() 来释放连接。这样可以确保每次只使用一个连接,并避免创建过多的连接。

相关内容

热门资讯

分享透视!wpk可以作弊吗,微... 分享透视!wpk可以作弊吗,微乐游戏竞技团辅助,技法教程(有挂分享)-哔哩哔哩1、进入到wpk可以作...
科普透视!wepoker钻石怎... 科普透视!wepoker钻石怎么看底牌,微乐广西麻辣辅助,练习教程(有挂技巧)-哔哩哔哩1、点击下载...
开挂透视!大菠萝辅助器,微信小... 开挂透视!大菠萝辅助器,微信小程序怎么开挂,练习教程(有挂存在)-哔哩哔哩1、许多玩家不知道大菠萝辅...
分享透视!德普之星辅助工具如何... 分享透视!德普之星辅助工具如何设置,微信小程序 微乐陕西挖坑 外挂,法子教程(有挂解密)-哔哩哔哩1...
揭幕透视!wepoker数据分... 揭幕透视!wepoker数据分析工具,微乐自建房辅助软件有哪些功能,法门教程(今日头条)-哔哩哔哩一...
专业透视!hhpoker是真的... 专业透视!hhpoker是真的假的,微乐山西脚本插件,指南教程(有挂方法)-哔哩哔哩1、hhpoke...
揭露透视!智星菠萝透视,微信小... 揭露透视!智星菠萝透视,微信小程序微乐安徽辅助器,绝活儿教程(有挂方法)-哔哩哔哩1、玩家可以在智星...
解迷透视!德普之星透视辅助软件... 解迷透视!德普之星透视辅助软件,微乐广西自建房免费黑科技下载,资料教程(讲解有挂)-哔哩哔哩1、实时...
揭幕透视!红龙poker辅助,... 揭幕透视!红龙poker辅助,微乐家乡麻辣自建房,教材教程(有挂教程)-哔哩哔哩1、让任何用户在无需...
有挂透视!pokemmo手机版... 有挂透视!pokemmo手机版透视脚本,微信小程序辅助多少钱,窍门教程(有挂方式)-哔哩哔哩1、po...