当前位置: 首页 > news >正文

Java:链接redis报错:NoSuchElementException: Unable to validate object

目录

    • 前言
    • 报错信息
    • 排查
      • 1、确认redis密码设置是否有效
      • 2、确认程序配置文件,是否配置了正确的redis登录密码
      • 3、检测是否是redis持久化的问题
      • 4、确认程序读取到的redis密码没有乱码
    • 原因
    • 解决


前言

一个已经上线的项目,生产环境的redis居然没有设置密码,后来因为漏洞扫描的时候发现了该问题,需要给redis加上密码,在密码加上之后,原本可以正常运行的程序在连接redis的时候出现报错


报错信息

redis.clients.jedis.exceptions.JedisException: Could not get a resource from the poolat redis.clients.util.Pool.getResource(Pool.java:51)at redis.clients.jedis.JedisPool.getResource(JedisPool.java:226)at com.xxx.util.JedisUtils.getJedis(JedisUtils.java:85)at com.xxx.itr.thread.JedisConsumeThread.run(JedisConsumeThread.java:76)
Caused by: java.util.NoSuchElementException: Unable to validate objectat org.apache.commons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:506)at org.apache.commons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:363)at redis.clients.util.Pool.getResource(Pool.java:49)... 3 more

排查

1、确认redis密码设置是否有效

在服务器连接redis,并使用auth命令输入登录密码,成功登录


2、确认程序配置文件,是否配置了正确的redis登录密码

redis密码与实际设置的密码一致


3、检测是否是redis持久化的问题

在服务器连接redis,执行ping命令,结果为:pong,排查持久化的问题

在这里插入图片描述


4、确认程序读取到的redis密码没有乱码

在程序上添加日志打印,将读取到的redis密码打印到日志文件

新加的日志并没有出现在日志文件!!!

再次确认,已将添加过日志打印的class文件更新到了tomcat/webapps目录下所对应的程序上,但日志还是没有成功打印出来!!!

出现以上情况,说明当前tomcat运行的并不是tomcat/webapps下的代码

检查tomcat配置,发现以下配置

在这里插入图片描述


原因

因配置原因,导致tomcat实际的运行代码并不在当前tomcat的webapps目录下,而且指向了其他的tomcat

因为redis设置了密码,而在当前tomcat程序的配置文件调整redis的密码实际上是没有成功读取到的

redis连接时需要密码,但程序启动时却没有带上密码,导致报错


解决

调整tomcat的配置文件,指向正确的目录(或者把指向程序代码的那项配置去掉,一般情况是不需要对程序代码的读取目录进行配置的)

http://www.lryc.cn/news/506439.html

相关文章:

  • datasets库之load_dataset
  • React Router常见面试题目
  • sequelize-cli 封装登录接口
  • 使用 Elasticsearch 查询和数据同步的实现方法
  • QTday1作业设置简易登录界面
  • RC低通滤波器和LR低通滤波器,LC低通滤波器该怎么选择
  • 芯旺微KF32A156芯片ADC配置
  • 【Token】校验、会话技术、登录请求、拦截器【期末实训】实战项目学生和班级管理系统\Day15-后端Web实战(登录认证)\讲义
  • [Unity Shader] 【游戏开发】【图形渲染】Shader数学基础3:矢量与标量的乘法与除法详解
  • javalock(四)AQS派生类之Semphore逐行注释
  • 【C语言】头文件”“和<>的详解
  • Elasticsearch:什么是信息检索?
  • Spark-Streaming容错语义
  • 2024年12月陪玩系统-仿东郊到家约玩系统是一种新兴的线上预约线下社交、陪伴系统分享-优雅草央千澈-附带搭建教程
  • GUI07-学工具栏,懂MVC
  • 【进程篇】04.进程的状态与优先级
  • ElasticSearch 数据聚合与运算
  • 科研学习|论文解读——智能体最新研究进展
  • 面试小札:Java后端闪电五连鞭_8
  • java error(2)保存时间带时分秒,回显时分秒变成00:00:00
  • 计算机毕业设计python+spark+hive动漫推荐系统 漫画推荐系统 漫画分析可视化大屏 漫画爬虫 漫画推荐系统 漫画爬虫 知识图谱 大数据毕设
  • 数字IC后端设计实现篇之TSMC 12nm TCD cell(Dummy TCD Cell)应该怎么加?
  • (8)YOLOv6算法基本原理
  • LNMP+discuz论坛
  • 在linux系统的docker中安装GitLab
  • Python面试常见问题及答案12
  • 从0-1开发一个Vue3前端系统页面-9.博客页面布局
  • [手机Linux] 六,ubuntu18.04私有网盘(NextCloud)安装
  • 白话java设计模式
  • 助力 Tuanjie OpenHarmony 开发:如何使用工具包 Hilog 和 SDK Kits Package?