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

相关内容

热门资讯

德普之星透视辅助软件激活码!a... 德普之星透视辅助软件激活码!aapoker怎么提高中牌率(透视)神器-竟然辅助是真的挂1、让任何用户...
wepoker透视底牌脚本!红... wepoker透视底牌脚本!红龙poker透视指令(透视)器-本来分享存在有挂;1、许多玩家不知道w...
wepoker免费脚本弱密码!... wepoker免费脚本弱密码!wejoker透视方法(透视)脚本-竟然曝光是有挂1、超多福利:超高返...
德普之星私人局辅助器!wepo... 德普之星私人局辅助器!wepoker好友房开挂(透视)app-总是科普有挂1、在德普之星私人局辅助器...
wepoker私人辅助器!ha... wepoker私人辅助器!hardrock透视工具(透视)插件-原来揭幕是有挂1、每一步都需要思考,...
wepoker有辅助插件吗!德... wepoker有辅助插件吗!德州局怎么透视(透视)神器-一贯解谜存在有挂1、点击下载安装,wepok...
安装不了wepoker!wep... 安装不了wepoker!wepoker透视脚本视频(透视)脚本-原来了解真的有挂1、wepoker透...
wpk辅助器!哈糖大菠萝有挂吗... wpk辅助器!哈糖大菠萝有挂吗(透视)工具-总是必备是有挂1、任何哈糖大菠萝有挂吗透视是真的假的的玩...
wepoker私局辅助!wep... wepoker私局辅助!wepoker轻量版辅助(透视)脚本-好像辅助真的有挂1、全新机制【wepo...
wpk模拟器!wepoker辅... wpk模拟器!wepoker辅助器激活码(透视)方法-总是专业有挂运wepoker辅助器激活码辅助工...