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辅助器!确实一直总是有辅助方法(讲解有挂)-哔哩哔哩1、微信小游戏...
第5分钟了解!蜀山四川亲友房辅... 第5分钟了解!蜀山四川亲友房辅助免费!总是一直都是有辅助脚本(有挂技术)-哔哩哔哩一、蜀山四川亲友房...
第九分钟了解!九九联盟辅助教程... 第九分钟了解!九九联盟辅助教程!总是真的是有辅助软件(证实有挂)-哔哩哔哩一、九九联盟辅助教程可以开...
8分钟了解!玩吧辅助工具!总是... 8分钟了解!玩吧辅助工具!总是真的是有辅助软件(有挂秘笈)-哔哩哔哩1.玩吧辅助工具 选牌创建新账号...
第3分钟了解!乐乐围棋入门插件... 第3分钟了解!乐乐围棋入门插件!确实是有辅助工具(有挂规律)-哔哩哔哩1、该软件可以轻松地帮助玩家将...
第4分钟了解!免费的衢州都莱辅... 第4分钟了解!免费的衢州都莱辅助器下载!本来存在有辅助神器(有挂头条)-哔哩哔哩1、不需要AI权限,...
第5分钟了解!智星德州插件最新... 第5分钟了解!智星德州插件最新版本更新内容详解!都是有辅助插件(有挂分享)-哔哩哔哩1、超多福利:超...
第9分钟了解!山城九九辅助!竟... 第9分钟了解!山城九九辅助!竟然一直都是有辅助教程(有挂教学)-哔哩哔哩1、用户打开应用后不用登录就...
1分钟了解!黑科技软件大全!其... 1分钟了解!黑科技软件大全!其实真的是有辅助脚本(有挂技巧)-哔哩哔哩1、点击下载安装,黑科技软件大...