【Dv3admin】ORM数据库无法查询的问题

Django 运行过程中,数据库连接的健康状态直接影响应用的稳定性和数据访问准确性。长时间空闲的数据库连接经常因外部机制被回收,进而引发数据查询异常和返回无效结果。

本文围绕 Django 中数据库连接长时间空闲导致的连接失效问题,介绍相关的背景成因,并给出配置与中间件层面的解决办法,包括如何自动检测与维护数据库连接的可用性,保障项目高可用和稳定运行。

文章目录

  • 应用场景
  • 实现方式
  • 总结

应用场景

Django 在运行过程中会维护自己的数据库连接池。如果连接被长时间占用或者在网络上处于空闲状态,有些数据库中间件、负载均衡器、云数据库自身的连接管理机制(比如超时、空闲回收)会自动断开这些连接。Django 并不会主动发现已有的连接已经失效,依然会用“假装还活着”的连接去请求数据。这时候,实际查询没有真正访问到数据库,ORM 返回 None,而不是抛出数据库连接异常。这种情况下,数据库层的数据并没有问题,只是 Django 进程用的连接已经失效,直到服务重启,连接池被清空并重新建立连接,才又能正常查到数据。

PaymentOrderFinance.objects.filter(id=123).first()

这种现象背后的根本原因,通常与数据库连接的“长时间空闲失效”有关。

  • 云数据库有连接超时或空闲连接回收策略,断掉了长时间未活跃的连接。
  • 网络不稳定,导致连接短暂丢失又自动恢复,但 ORM 没有感知到。
  • 负载均衡层或者中间件(比如 ProxySQL、云数据库代理层)清理了“空闲连接”。

实现方式

可以在 Django 的数据库配置中添加 CONN_MAX_AGE(连接最大存活时间),比如设置为 60 秒或者更短,让 Django 自动定期重建连接,减少连接失效的概率。还可以用数据库健康检查机制,或者用中间件对查询失败做重试处理。
例如:

DATABASES = {'default': {# ...'CONN_MAX_AGE': 60,  # 单位为秒}
}

这样 Django 会自动在每次查询时判断连接是否存活,超过设置时间会重连数据库,从而避免这种“假死连接”导致的 None 返回。

并项目下新建中间件 db_keepalive.py 定义一个 Django 中间件类 EnsureDbConnectionMiddleware,用于每次 HTTP 请求到来时自动检测并维护数据库连接的可用性。具体来说,中间件在请求处理流程的最前面调用 connection.close_if_unusable_or_obsolete(),确保如果当前数据库连接已经失效或变得不可用,就会自动关闭这个连接,避免后续操作因连接异常导致报错。这样可以减少数据库连接因长时间空闲或网络问题导致的不可用情况,保证后续每一次数据库访问时连接状态都是健康的。这个中间件适用于需要高可用、稳定数据库连接的场景,比如长时间运行的 Web 服务,能够有效预防由于数据库连接断开引起的异常。

# coding:utf-8
'''
@IDE     :PyCharm 
@Project :ManageBak-HS.py 
@File    :db_keepalive.py
@Author  :Mr数据杨
@Date    :2025/7/25
@Desc    : 
'''from django.db import connectionclass EnsureDbConnectionMiddleware:def __init__(self, get_response):self.get_response = get_responsedef __call__(self, request):# 每次请求自动检测数据库连接connection.close_if_unusable_or_obsolete()response = self.get_response(request)return response

在 Django 项目的 settings.py 文件的 MIDDLEWARE 配置中,将这个中间件类添加到合适的位置后,即可实现对所有请求的数据库连接健康管理,提升系统的健壮性和稳定性。

MIDDLEWARE = ["dvadmin.utils.middleware.ApiLoggingMiddleware", # 必须第一个.......
]

总结

数据库连接因空闲被回收引发的失效现象,常见于云数据库、负载均衡或网络环境下,容易导致数据查询异常。通过合理设置 CONN_MAX_AGE 参数和添加数据库连接健康检测中间件,可以有效降低“假死连接”产生的概率,提升查询准确性和系统稳定性。

针对生产环境,建议结合实际场景持续优化数据库连接管理策略,关注不同数据库平台的连接处理细节。未来,结合自动化健康监测与智能重连机制,有望进一步提升 Django 应用的高可用能力,减少因底层连接断开带来的潜在风险。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/93549.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/93549.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用 Flownex 对机械呼吸机进行建模

当患者无法独立呼吸时,机械呼吸机通过气管插管将富氧空气输送到患者的肺部。肺是敏感而复杂的器官,因此在无法忍受的压力和体积范围内提供空气,根据每分钟所需的呼吸次数计时,并适当加湿和加热。机械呼吸机的精确建模对于其安全有…

力扣刷题日常(7-8)

力扣刷题日常(7-8) 第7题: 整数反转(难度: 中等) 原题: 给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果. 如果反转后整数超过 32 位的有符号整数的范围 [−231, 231 − 1] ,就返回 0. 假设环境不允许存储 64 位整数(有符号或无符号).…

串口接收数据包(协议带帧头帧尾)的编程实现方法:1、数据包格式定义结构体2、使用队列进行数据接收、校验解包

这种带帧头帧尾的数据包处理流程可以简单概括为 “识别边界→提取有效数据→验证完整性” 三个核心步骤,具体操作如下:1. 数据包格式定义(先约定规则)首先明确一个 “合格数据包” 的结构,比如: 帧头&#…

JSON 对象封装教程

JSON 对象封装方法在 Java 中封装 JSON 对象通常使用第三方库&#xff0c;如 org.json、Gson 或 Jackson。以下是几种常见的方法&#xff1a;使用 org.json 库添加 Maven 依赖&#xff1a;<dependency><groupId>org.json</groupId><artifactId>json<…

【WRF-Chem】EDGAR 排放数据处理:分部门合并转化为二进制(Python全代码)

目录 process.py process_biofl.py process_fossil.py process_micro.py process_sector.py 参考 process.py 读取 EDGAR 排放数据库中 2000 至 2023 年间不同行业的甲烷(CH₄)排放数据,进行合并处理,并将总排放以二进制格式保存到文件中。 导入必要的库 import numpy as n…

【学习过程记录】【czsc】1、安装

文章目录 背景 安装 安装python 安装czsc 功能测试 附录 奇葩的报错 背景 详见: https://github.com/waditu/czsc 安装 安装python !重要!作者强调,python必须是大于等于3.8 为此呢,我也是花了一点时间装了一个python3.13。 安装czsc 关于czsc的安装呢,官方也是给出…

Python批量生成N天前的多word个文件,并根据excel统计数据,修改word模板,合并多个word文件

1&#xff0c;需求 根据word模板文件&#xff0c;生成多个带日期后缀的word文件根据excel-每日告警统计数量&#xff0c;逐个修改当日的文档2&#xff0c;实现 shell脚本&#xff1a;根据word模板文件&#xff0c;生成多个带日期后缀的word文件 #!/bin/bash # 生成近一年日期 …

基于uni-app的血糖血压刻度滑动控件

想要做一个基于uni-app的血糖血压刻度滑动控件&#xff0c;hbuilder市场没有好的&#xff0c;参照别人的写了一个。如图&#xff1a;源码&#xff0c;自己放入components里面。<!-- 刻度滑动选择 --> <template><view><view class"slide-title"…

C语言(02)——标准库函数大全(持续更新)

想要了解更多的C语言知识&#xff0c;可以订阅下面的专栏&#xff0c;里面也有很多品质好文&#xff1a; 打怪升级之路——C语言之路_ankleless的博客-CSDN博客 还在持续更新中&#xff0c;以下是学习过程中遇到的一些库函数&#xff08;排序不分先后&#xff09;&#xff1a…

永磁同步电机无速度算法--静态补偿电压模型Harnefors观测器

一、原理介绍本文基于Harnefors教授提出的静态补偿电压模型&#xff0c;可以实现带载零速启动、正反转切换等功能&#xff0c;原理清晰&#xff0c;实现简便。二、仿真模型在MATLAB/simulink里面验证所提算法&#xff0c;搭建仿真。采用和实验中一致的控制周期1e-4&#xff0c;…

[SKE]Python gmssl库的C绑定

Python gmssl库的C绑定 摘要:本文展示gmssl库的C绑定,并给出完整代码。将参考模型从Python脚本迁移到纯C代码中使用gmssl库(TongSuo项目,支持国密算法如SM4,同时兼容AES、DES、3DES、RSA等)。这样,UVM(SystemVerilog)可以通过DPI-C直接调用C函数,而无需嵌入Py…

4.方法的使用

方法是指一段具有独立功能的代码块&#xff0c;只有被调用时才会执行方法的主要作用体现在&#xff1a;代码组织&#xff1a;将原本挤在一起的臃肿代码按照功能进行分类管理例如&#xff1a;将用户注册的验证逻辑、数据库操作、结果返回等分离成不同方法提高复用性&#xff1a;…

day21-Excel文件解析

目录 1. 概述 2. Apache POI 3. XSSF解析Excel文件 3.1. 添加Jar包依赖 3.2. Workbook&#xff08;Excel文件&#xff09; 3.2.2. 加载&#xff08;解析&#xff09;Excel文件 3.3. Sheet &#xff08;工作簿&#xff09; 3.3.1. 创建工作簿 3.3.2. 获取工作簿 3.3.3.…

与 TRON (波场) 区块链进行交互的命令行工具 (CLI): tstroncli

源码仓库 一个基于 Node.js 和 TypeScript 构建的&#xff0c;用于与 TRON (波场) 区块链进行交互的命令行工具 (CLI)。 本项目旨在提供一个简单、可扩展的框架&#xff0c;让开发者可以轻松地通过命令行调用 TRON 的 HTTP API&#xff0c;实现查询链上信息、发送交易等操作。…

rabbitmq--默认模式(点对点)

导入包&#xff1a;<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId> </dependency>application.yml springrabbitmq:host: localhostport: 5672username: guestpassword: gue…

外网访问文档编辑器Docsify(Windows版本),内网穿透技术应用简便方法

如果你正在为项目写文档&#xff0c;但又不想折腾复杂的构建流程&#xff0c;也不想维护一堆静态 HTML 文件&#xff0c;那你一定要试试 docsify。docsify 是一个基于 JavaScript 的开源文档生成工具&#xff0c;它最大的特点就是“无构建”&#xff1a;你只需要写 Markdown 文…

第4章唯一ID生成器——4.5 美团点评开源方案Leaf

Leaf是美团点评公司基础研发平台推出的一个唯一ID生成器服务&#xff0c;其具备高可靠性、低延迟、全局唯一等特点&#xff0c;目前已经被广泛应用于美团金融、美团外卖、美团酒旅等多个部门。Leaf根据不同业务的需求分别实现了Leaf-segment和Leaf-snowflake两种方案&#xff0…

分布式搜索和分析引擎Elasticsearch实战指南

ES 介绍与安装 Elasticsearch&#xff0c; 简称 ES&#xff0c;它是个开源分布式搜索引擎&#xff0c;它的特点有&#xff1a;分布式&#xff0c;零配置&#xff0c;自动发现&#xff0c;索引自动分片&#xff0c;索引副本机制&#xff0c;restful 风格接口&#xff0c;多数据源…

【13】C# 窗体应用WinForm——.NET Framework、WinForm、工程创建、工具箱简介、窗体属性及创建

文章目录1. WinForm工程创建 及 界面介绍1.1 WinForm工程创建1.2 窗体 Form1.cs “查看代码”1.3 打开窗体设计器2. 工具箱3. 窗体属性及创建3.1 窗体属性3.2 实例&#xff1a;创建一个新窗体3.2.1 添加新Windows窗体3.2.2 窗体属性配置3.2.3 设置该窗体为启动窗体WinForm 是 W…

论文阅读-IGEV

文章目录1 概述2 模块2.1 总体说明2.2 特征抽取器2.3 CGEV2.4 基于Conv-GRU的更新算子2.5 空间上采样2.6 损失函数3 效果参考文献1 概述 在双目深度估计中&#xff0c;有一类是基于3D卷积的方法&#xff0c;代表就是PSMNet&#xff0c;它应用 3D 卷积编码器-解码器来聚合和正则…