sqlalchemy连接池满了报错

报错信息

sqlalchemy.exc.TimeoutError: QueuePool limit of size 5 overflow 10 reached, connection timed out, timeout 30 (Background on this error at: http://sqlalche.me/e/3o7r)

解决办法

参考https://docs.sqlalchemy.org/en/20/core/pooling.html

在创建数据库engine时指定连接池pool_size及可接受的溢出max_overflow大小

python 复制代码
engine = create_engine(
    "postgresql+psycopg2://me@localhost/mydb", pool_size=20, max_overflow=0
)
  • pool_size:要维护的池的大小,默认为5。这是池中持久保留的最大连接数。请注意,池开始时没有连接;一旦请求了此数量的连接,该数量的连接将保持不变。pool_size可以设置为0以指示没有大小限制;若要禁用池,请改用NullPool
  • max_overflow:池的最大溢出大小。当连接数达到pool_size中设置的大小时,将返回不超过此限制的其他连接。当这些附加连接返回到池时,它们将断开连接并被丢弃。因此,池将允许的同时连接的总数是pool_size+max_overflow,并且池将允许"睡眠"连接的总数为pool_sizemax_overflow可以设置为-1表示没有溢出限制;对并发连接的总数没有限制。默认值为10
  • 其他参数timeout:连接等待超时时间
  • 其他参数use_lifo:检索连接时使用后进先出(LIFO),而不是FIFO(先进先出)。使用LIFO,服务器端超时方案可以减少非高峰使用期间使用的连接数量。在计划服务器端超时时,请确保使用回收或预ping策略来优雅地处理过时的连接。

注意事项

The QueuePool class is not compatible with asyncio. When using create_async_engine to create an instance of AsyncEngine, the AsyncAdaptedQueuePool class, which makes use of an asyncio-compatible queue implementation, is used instead.

翻译

sqlalchemy的连接池队列sqlalchemy.pool.QueuePool不兼容asyncio

相关推荐
xcLeigh2 小时前
IoTDB 数据导入全攻略:工具、自动加载与 Load SQL 详解
数据库·sql·工具·iotdb·数据导入·loadsql
清水白石0082 小时前
隔离的艺术:用 `unittest.mock` 驯服外部依赖,让测试真正可控
python
码农小韩2 小时前
AIAgent应用开发——大模型理论基础与应用(五)
人工智能·python·提示词工程·aiagent
百锦再2 小时前
Java中的char、String、StringBuilder与StringBuffer 深度详解
java·开发语言·python·struts·kafka·tomcat·maven
Jonathan Star3 小时前
Ant Design (antd) Form 组件中必填项的星号(*)从标签左侧移到右侧
人工智能·python·tensorflow
清漠2333 小时前
win11“网络和Internet“中无“以太网“这个选项解决记录
服务器·网络·数据库
努力努力再努力wz3 小时前
【Linux网络系列】:TCP 的秩序与策略:揭秘传输层如何从不可靠的网络中构建绝对可靠的通信信道
java·linux·开发语言·数据结构·c++·python·算法
deep_drink3 小时前
【论文精读(三)】PointMLP:大道至简,无需卷积与注意力的纯MLP点云网络 (ICLR 2022)
人工智能·pytorch·python·深度学习·3d·point cloud
njsgcs4 小时前
langchain+vlm示例
windows·python·langchain
勇气要爆发4 小时前
LangGraph 实战:10分钟打造带“人工审批”的智能体流水线 (Python + LangChain)
开发语言·python·langchain