测试环境项目启动redis报错

目录

    • 一、背景
    • 二、排查过程及原因
      • (一)、排查过程
      • (二)、原因
    • 三、解决方法
    • 四、总结

一、背景

项目没有改任何配置文件,突然测试环境启动不起来,报一堆和redis相关的错误,但是本地启动没有任何问题。都是相同的代码。

二、排查过程及原因

(一)、排查过程

1、一开始怀疑是数据库或者redis相关配置文件被人为修改了,经过检查发现没有变动
2、通过redis报错的相关代码加入日志,发现注入的RedisTemplate为null
查看服务器日志
检查是否有以下错误:
biRedisTemplate Bean 初始化失败(如配置错误)。
调用 BIRedisUtil 静态方法时的空指针异常堆栈。
添加日志跟踪
在 setRedisTemplate() 方法中记录注入是否成功:

@Autowired
@Qualifier("biRedisTemplate")
public void setRedisTemplate(RedisTemplate redisTemplate) {log.info("Injecting biRedisTemplate: {}", redisTemplate);BIRedisUtil.redisTemplate = redisTemplate;
}

若服务器日志中无此信息,说明注入未触发。
静态方法添加空指针保护

public static String get(String key) {if (stringRedisTemplate == null) {log.error("stringRedisTemplate is null!");return null;}return stringRedisTemplate.opsForValue().get(key);
}

(二)、原因

  1. Spring 依赖注入机制不直接支持静态变量
    Spring 的 @Autowired 注解默认针对实例成员,而非静态变量。
    虽然文件2通过 setter 方法尝试将 Bean 注入静态变量:
@Autowired
@Qualifier("biRedisTemplate")
public void setRedisTemplate(RedisTemplate redisTemplate) {BIRedisUtil.redisTemplate = redisTemplate; // 赋值给静态变量
}

但以下问题会导致注入失败:

  • 初始化顺序不可控

Spring 容器初始化时,静态变量的赋值可能晚于其他 Bean 的初始化。
例如:若某个 Bean 在初始化时直接调用 BIRedisUtil.batchQuery(),而 setRedisTemplate() 方法尚未执行,此时 redisTemplate 仍为 null。

静态变量的生命周期与 Bean 不同步 静态变量在类加载时被初始化为 null,而 Spring 依赖注入发生在 Bean 实例化后。若注入过程中发生异常(如 Bean 未定义或配置错误),静态变量会保持 null。

  1. 本地与服务器环境的差异
    本地环境
    可能因以下原因掩盖问题:

测试数据量小,未触发多线程并发场景。 依赖的 Bean 初始化顺序恰好正确(如先调用 setRedisTemplate() 后使用静态方法)。 Redis 配置简单,Bean 初始化无异常。

服务器环境
以下问题会暴露缺陷:

复杂依赖链:Bean 初始化顺序更复杂,可能先使用静态方法后注入变量。 并发请求:高并发下多个线程同时访问未初始化的redisTemplate,导致空指针。 配置错误:服务器 Redis 连接参数(如地址、密码)错误,导致 biRedisTemplate> Bean 初始化失败,setRedisTemplate() 未被调用。

  1. 静态变量的线程安全问题

即使注入成功,RedisTemplate 作为静态变量被多线程共享时: 若 RedisTemplate内部状态非线程安全(如连接池管理),可能导致数据错乱。 服务器高并发场景下,问题会被放大,而本地低并发测试可能无法复现。

三、解决方法

  1. 改为实例变量(推荐)
    移除 static 关键字,通过 Spring 管理实例:
@Component
public class BIRedisUtil {private RedisTemplate redisTemplate; // 非静态变量@Autowiredpublic void setRedisTemplate(RedisTemplate redisTemplate) {this.redisTemplate = redisTemplate; // 注入实例变量}
}
  1. 强制初始化顺序(不推荐)
    使用 @DependsOn 确保 BIRedisUtil 在其他 Bean 之后初始化:
@Component
@DependsOn("biRedisTemplate") // 依赖 biRedisTemplate 先初始化
public class BIRedisUtil { ... }
  1. 使用 @PostConstruct 初始化静态变量
private static RedisTemplate redisTemplate;
@Autowired
@Qualifier("biRedisTemplate")
private RedisTemplate _redisTemplate; // 实例变量接收注入@PostConstruct
public void init() {BIRedisUtil.redisTemplate = this._redisTemplate; // 转赋给静态变量
}

四、总结

核心原因是 Spring 不直接支持静态变量注入,导致依赖注入的时序不可控。服务器环境因复杂的初始化流程和高并发场景,更容易暴露此问题。改用实例变量是根本解决方案。

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

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

相关文章

深入理解椭圆曲线密码学(ECC)与区块链加密

椭圆曲线密码学(ECC)在现代加密技术中扮演着至关重要的角色,广泛应用于区块链、数字货币、数字签名等领域。由于其在提供高安全性和高效率上的优势,椭圆曲线密码学成为了数字加密的核心技术之一。本文将详细介绍椭圆曲线的基本原理…

SQL Server 2008安装教程

目录 一.安装SQL Server 二.安装SQL Server Management Studio 三.使用SQL Server Management Studio 一.安装SQL Server 官网下载:SQL Server 下载 | Microsoft 1.选择安装中的全新安装如下图 2.功能选择 3.实例配置 4.后面一直下一步到数据库引擎配置 密码自己设置 系统…

Microi吾码界面设计引擎之基础组件用法大全【内置组件篇·中】

🎀🎀🎀 microi-pageengine 界面引擎系列 🎀🎀🎀 一、Microi吾码:一款高效、灵活的低代码开发开源框架【低代码框架】 二、Vue3项目快速集成界面引擎 三、Vue3 界面设计插件 microi-pageengine …

如何在 Windows 上安装并使用 Postman?

Postman 是一个功能强大的API测试工具,它可以帮助程序员更轻松地测试和调试 API。在本文中,我们将讨论如何在 Windows 上安装和使用 Postman。 Windows 如何安装和使用 Postman 教程?

便携版:随时随地,高效处理 PDF 文件

PDF-XChange Editor Plus 便携版是一款功能强大且极其实用的 PDF 阅读与编辑工具。它不仅支持快速浏览 PDF 文件,还提供了丰富的编辑功能,让用户可以轻松处理 PDF 文档。经过大神优化处理,这款软件已经变得十分轻便,非常适合需要随…

MCP Server 实现一个 天气查询

​ Step1. 环境配置 安装 uv curl -LsSf https://astral.sh/uv/install.sh | shQuestion: 什么是 uv 呢和 conda 比有什么区别? Answer: 一个用 Rust 编写的超快速 (100x) Python 包管理器和环境管理工具,由 Astral 开发。定位为 pip 和 venv 的替代品…

MySQL执行计划

MySQL 的 执行计划(Execution Plan) 是优化器根据 SQL 语句生成的查询执行路径的详细说明。通过分析执行计划,可以了解 MySQL 如何处理 SQL 查询(如索引使用情况、表连接顺序等),进而优化查询性能。 1. 获…

数据大屏点亮工业互联网的智慧之眼

在当今数字化飞速发展的时代,数据已成为企业决策的核心依据,而数据大屏作为数据可视化的重要工具,正逐渐成为工业互联网领域不可或缺的一部分。通过直观、动态的可视化展示,数据大屏能够将复杂的数据转化为易于理解的图表和图形&a…

GPT-SoVITS本地部署:低成本实现语音克隆远程生成音频全流程实战

文章目录 前言1.GPT-SoVITS V2下载2.本地运行GPT-SoVITS V23.简单使用演示4.安装内网穿透工具4.1 创建远程连接公网地址 5. 固定远程访问公网地址 前言 今天要给大家安利一个绝对能让你大呼过瘾的声音黑科技——GPT-SoVITS!这款由花儿不哭大佬精心打造的语音克隆神…

【AI大模型】DeepSeek + 通义万相高效制作AI视频实战详解

目录 一、前言 二、AI视频概述 2.1 什么是AI视频 2.2 AI视频核心特点 2.3 AI视频应用场景 三、通义万相介绍 3.1 通义万相概述 3.1.1 什么是通义万相 3.2 通义万相核心特点 3.3 通义万相技术特点 3.4 通义万相应用场景 四、DeepSeek 通义万相制作AI视频流程 4.1 D…

【Unity】合批处理和GPU实例化的底层优化原理(完)

【Unity】批处理和实例化的底层优化原理 URP1.基础概念SetPassCallsDrawCallsBatches 2.重要性排序既然如此为什么仍然要合批? 3.unity主流的合批优化方案和优先级Early-Z透明物体情况 4.合批(小场景但是很复杂很多小物件刚需)合并纹理图集更…

当人类关系重构:从“相互需要”到“鹅卵石化”——生成式人工智能(GAI)认证的角色与影响

在数字化浪潮的席卷之下,人类社会正经历着前所未有的变革。人与人之间的连接方式、互动模式以及价值认同,都在悄然发生着变化。这一过程中,一个显著的现象是,人与人之间的关系逐渐从传统的“相互需要”模式,转变为一种更为复杂、多元且稳定的“鹅卵石化”结构。在此背景下…

ctfhow——web入门171~175

sql简介 web入门171 ——判断注入点: -1 union select 1,2,3 -- 其实在这之前可以先判断多少列,即 -1‘ group(order) by 3 -- group by用于将具有相同值的行分组成一个汇总行,可以查看是否报错确定列数 2&#x…

vue遗漏的知识点(动态组件.组件库的操作使用)

----动态组件&#xff08;vue2vue3通用&#xff09; <component :is"..."> 的作用 <component> 是 Vue 的内置组件&#xff0c;用于动态渲染其他组件。:is 属性 用于指定要渲染的组件。它的值可以是&#xff1a; 组件的名称&#xff08;字符串&#xf…

ip改变导致的数据库连接不上

前言 需要用到路由器&#xff0c;所以先把家里的路由器给拆了先用着。新的路由器到了之后&#xff0c;更换上新的路由器之后&#xff0c;调用到服务会有报错&#xff0c;记录一下更换路由器之后ip重新分配服务可能会报的错. 进一步可以看到有关网路在服务当中的影响。 正文 …

DeepSeek面试——模型架构和主要创新点

本文将介绍DeepSeek的模型架构多头潜在注意力&#xff08;MLA&#xff09;技术&#xff0c;混合专家&#xff08;MoE&#xff09;架构&#xff0c; 无辅助损失负载均衡技术&#xff0c;多Token 预测&#xff08;MTP&#xff09;策略。 一、模型架构 DeepSeek-R1的基本架构沿用…

基于HTML5的3D魔方项目开发实践

基于HTML5的3D魔方项目开发实践 这里写目录标题 基于HTML5的3D魔方项目开发实践项目概述核心技术实现1. 3D效果实现CSS3 3D变换魔方结构设计 2. 交互控制实现动画控制键盘控制触摸控制 技术难点与解决方案1. 3D变换控制2. 触摸体验优化3. 动画性能优化 项目收获总结项目展望 项…

23种设计模式-原型(Prototype)设计模式

原型设计模式 &#x1f6a9;什么是原型设计模式&#xff1f;&#x1f6a9;原型设计模式的特点&#x1f6a9;原型设计模式的结构&#x1f6a9;原型设计模式的优缺点&#x1f6a9;原型设计模式的Java实现&#x1f6a9;代码总结&#x1f6a9;总结 &#x1f6a9;什么是原型设计模式…

【MATLAB例程】交互式多模型(IMM),模型使用:CV,CT左转、CT右转,二维平面,三个模型的IMM,滤波使用EKF。订阅专栏后可查看代码

简单的介绍:本文所述的代码实现了一种基于交互多模型(IMM)算法的目标跟踪仿真,适用于复杂运动目标(如匀速、转弯运动)的状态估计。代码通过三个运动模型(匀速CV、左转弯CT1、右转弯CT2)的协同滤波,动态调整模型概率,最终输出综合跟踪结果。代码包含完整的仿真数据生成…

搭建私人对外git空间

# 创建用户&#xff0c;指定不可登录的 Shell&#xff08;git-shell 或 /usr/sbin/nologin&#xff09; sudo adduser --system --shell /usr/bin/git-shell --group git # 验证用户配置 grep git /etc/passwd # 预期输出&#xff1a;git:x:998:998::/home/git:/usr/bin/git-s…