本文主要是介绍SpringBoot 启动报错 Unable to connect to Redis server: 127.0.0.1/127.0.0.1:6379 问题解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
🚀 作者主页: 有来技术
🔥 开源项目: youlai-mall 🍃 vue3-element-admin 🍃 youlai-boot
🌺 仓库主页: Gitee 💫 Github 💫 GitCode
💖 欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请纠正!
目录
- 问题描述
- 原因分析
- 源码分析
- 解决方案
问题描述
使用开源项目 youlai-boot 中,使用默认线上配置没问题的,但将 Redis 的修改为本地的环境出现无法连接的错误
启动项目报错关键信息:
org.redisson.client.RedisConnectionException: Unable to connect to Redis server: 127.0.0.1/127.0.0.1:6379
稍微完整的错误信息:
org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'securityConfig' defined in file [D:\Project\Work\youlai-boot\target\classes\com\youlai\system\config\SecurityConfig.class]: Unsatisfied dependency expressed through constructor parameter 2: Error creating bean with name 'redisTemplate' defined in class path resource [com/youlai/system/config/RedisConfig.class]: Unsatisfied dependency expressed through method 'redisTemplate' parameter 0: Error creating bean with name 'redissonConnectionFactory' defined in class path resource [org/redisson/spring/starter/RedissonAutoConfigurationV2.class]: Unsatisfied dependency expressed through method 'redissonConnectionFactory' parameter 0: Error creating bean with name 'redisson' defined in class path resource [org/redisson/spring/starter/RedissonAutoConfigurationV2.class]: Failed to instantiate [org.redisson.api.RedissonClient]: Factory method 'redisson' threw exception with message: java.util.concurrent.ExecutionException: org.redisson.client.RedisConnectionException: Unable to connect to Redis server: 127.0.0.1/127.0.0.1:6379
错误截图:
原因分析
再看下修改前后的对比图
线上 Redis 服务配置了密码,而本地 Redis 服务没有密码,因此我们理所当然地将 password
的值留空。然而,这正是问题的根本原因,因为空值仍会被解析为一个空字符串,而不是被忽略。
如果只是这样说是没有说服力的,接下来我将本着“源码面前无秘密”的原则,深入揭示问题的本质。
源码分析
假设本地的 Redis 未配置密码,SpringBoot 的 Redis 连接配置如下:
spring:data:redis:database: 0host: 127.0.0.1port: 6379password:
MasterSlaveConnectionManager#createClient
根据配置创建客户端,其中配置的 password 是空字符串而不是null。
BaseConnectionHandler#channelActive
方法根据配置进行 Redis 客户端连接初始化。由于配置中的 password 被解析成空字符串而非 null,因此尝试使用空字符串作为密码连接 Redis,但由于 Redis 服务未设置密码,连接失败。
解决方案
由上可知,如果将配置的 password 值设置为空,则客户端在连接时会使用空字符串作为密码进行认证。由于服务端未设置密码,因此连接失败。
解决方法其实很简单,如果 Redis 服务未设置密码,需要将 password 注释或删除,而不是设置为空字符串。
spring:data:redis:database: 0host: 127.0.0.1port: 6379# 如果 Redis 服务未设置密码,需要将 password 删除或注释,而不是设置为空字符串# password:
再次调试可以看到 password 为 null ,直接跳过密码认证,直接返回已完成的 CompletableFuture 对象
这篇关于SpringBoot 启动报错 Unable to connect to Redis server: 127.0.0.1/127.0.0.1:6379 问题解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!