python - 编码/数据库库的数据库连接问题
问题描述
我有一个错误
pymysql.err.InternalError: Packet sequence number wrong - got 0 expected 1
在让我的应用程序空闲(0 个对 DB 的请求)几个小时后。我想,数据库模块会创建连接池(确实如此)并在超时后自动重新创建连接,但事实并非如此。
要求 - Python 3.8、FastAPI、数据库[mysql]。
有任何想法吗 ?
主文件
.......
@app.on_event("startup")
async def startup():
await db.connect()
@app.on_event("shutdown")
async def shutdown():
await db.disconnect()
.......
db_config.py
import databases
import sqlalchemy
import os
import logging
from functools import wraps
HOST = 'mysql://user:user_passw@{host}:{port}/sw_database'.format(host=os.environ.get("DB_HOST", "127.0.0.1"),
port=os.environ.get("DB_PORT", "3306"))
db = databases.Database(HOST)
metadata = sqlalchemy.MetaData()
logger = logging.getLogger(__name__)
def perform_transaction(foo):
@wraps(foo)
async def decorate(*args, **kwargs):
async with db.connection() as connection:
async with connection.transaction():
try:
res = await foo(*args, **kwargs)
except Exception as e:
logger.error(e)
return []
return res
return decorate
端点示例
from fastapi import APIRouter
from db_config import db, perform_transaction
router = APIRouter()
@router.get('/devices_list', responses=responses_for_devices_table)
@perform_transaction
async def get_devices_list():
query = devices.select()
return await db.fetch_all(query)
解决方案
您可以使用该pool_recycle
参数来确保连接池丢弃或重新连接任何因空闲时间过长的连接。3600 的设置通常适用于 MySQL - 它会在空闲一个小时后回收连接。
您可以将其作为参数提供给Database(.., pool_recycle=3600)
,或作为连接字符串 ( ...?pool_recycle=3600
) 中的选项:
db = databases.Database(HOST, pool_recycle=3600)
.. 或者
HOST = 'mysql://user:user_passw@{host}:{port}/sw_database?pool_recycle=3600'.format(..)
推荐阅读
- java - 使用子流创建未连接的 PublishSubscribeChannel
- python - 在 Heroku 应用上安装 spacy en_core_web_lg 时出错
- c# - ASP.NET 中的“CS1003:语法错误,','预期”
- python - 当我们想组合 re.IGNORECASE 和 re.DOTALL 时,为什么要使用按位或运算符?
- c - 使用 AVX 提高浮点减法、除法、截断到 int32 的性能
- java - Kotlin Compiler Plugin:如何检查属性是否有注释?
- c - 从“int”类型分配给“__m256d”类型时不兼容的类型
- mysql - MySQL:计算 ETF 投资组合的加权持股量,得到一个包含所有持股量的列表
- html - 如何使用 CSS 动画将元素从左向右移动?
- java - 错误膨胀类 androidx.appcompat.widget.Toolbar android