SpringBoot 啟動(dòng)報(bào)錯(cuò)Unable to connect to Redis server: 127.0.0.1/127.0.0.1:6379問(wèn)題的解決方案
問(wèn)題描述
使用開(kāi)源項(xiàng)目 youlai-boot 中,使用默認(rèn)線上配置沒(méi)問(wèn)題的,但將 Redis 的修改為本地的環(huán)境出現(xiàn)無(wú)法連接的錯(cuò)誤

啟動(dòng)項(xiàng)目報(bào)錯(cuò)關(guān)鍵信息:
org.redisson.client.RedisConnectionException: Unable to connect to Redis server: 127.0.0.1/127.0.0.1:6379
稍微完整的錯(cuò)誤信息:
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
錯(cuò)誤截圖:

原因分析
再看下修改前后的對(duì)比圖

線上 Redis 服務(wù)配置了密碼,而本地 Redis 服務(wù)沒(méi)有密碼,因此我們理所當(dāng)然地將 password 的值留空。然而,這正是問(wèn)題的根本原因,因?yàn)榭罩等詴?huì)被解析為一個(gè)空字符串,而不是被忽略。
如果只是這樣說(shuō)是沒(méi)有說(shuō)服力的,接下來(lái)我將本著“源碼面前無(wú)秘密”的原則,深入揭示問(wèn)題的本質(zhì)。
源碼分析
假設(shè)本地的 Redis 未配置密碼,SpringBoot 的 Redis 連接配置如下:
spring:
data:
redis:
database: 0
host: 127.0.0.1
port: 6379
password:
MasterSlaveConnectionManager#createClient 根據(jù)配置創(chuàng)建客戶(hù)端,其中配置的 password 是空字符串而不是null。

BaseConnectionHandler#channelActive 方法根據(jù)配置進(jìn)行 Redis 客戶(hù)端連接初始化。由于配置中的 password 被解析成空字符串而非 null,因此嘗試使用空字符串作為密碼連接 Redis,但由于 Redis 服務(wù)未設(shè)置密碼,連接失敗。

解決方案
由上可知,如果將配置的 password 值設(shè)置為空,則客戶(hù)端在連接時(shí)會(huì)使用空字符串作為密碼進(jìn)行認(rèn)證。由于服務(wù)端未設(shè)置密碼,因此連接失敗。
解決方法其實(shí)很簡(jiǎn)單,如果 Redis 服務(wù)未設(shè)置密碼,需要將 password 注釋或刪除,而不是設(shè)置為空字符串。
spring:
data:
redis:
database: 0
host: 127.0.0.1
port: 6379
# 如果 Redis 服務(wù)未設(shè)置密碼,需要將 password 刪除或注釋?zhuān)皇窃O(shè)置為空字符串
# password:
再次調(diào)試可以看到 password 為 null ,直接跳過(guò)密碼認(rèn)證,直接返回已完成的 CompletableFuture 對(duì)象

以上就是SpringBoot 啟動(dòng)報(bào)錯(cuò)Unable to connect to Redis server: 127.0.0.1/127.0.0.1:6379問(wèn)題的解決方案的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot 啟動(dòng)報(bào)錯(cuò)Unable connect Redis的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- SpringBoot項(xiàng)目啟動(dòng)錯(cuò)誤:找不到或無(wú)法加載主類(lèi)的三種解決方法
- spring boot啟動(dòng)出現(xiàn)Unable to start ServletWebServerApplicationContext due to missing ServletWebServer錯(cuò)誤解決
- 查看本地啟動(dòng)SpringBoot的本地端口號(hào)的幾種方式
- SpringBoot中@Scheduled實(shí)現(xiàn)服務(wù)啟動(dòng)時(shí)執(zhí)行一次
- SpringBoot應(yīng)用啟動(dòng)慢的原因分析及優(yōu)化方法
- Spring boot啟動(dòng)原理及相關(guān)組件整理
相關(guān)文章
Springboot動(dòng)態(tài)切換數(shù)據(jù)源的具體實(shí)現(xiàn)與原理分析
目前有個(gè)需求,需要使用不同的數(shù)據(jù)源,例如某業(yè)務(wù)要用A數(shù)據(jù)源,另一個(gè)業(yè)務(wù)要用B數(shù)據(jù)源,所以下面這篇文章主要給大家介紹了關(guān)于Springboot動(dòng)態(tài)切換數(shù)據(jù)源的具體實(shí)現(xiàn)與原理分析,需要的朋友可以參考下2021-12-12
Mybatis中自定義實(shí)例化SqlSessionFactoryBean問(wèn)題
這篇文章主要介紹了Mybatis中自定義實(shí)例化SqlSessionFactoryBean問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
MyBatis動(dòng)態(tài)sql查詢(xún)及多參數(shù)查詢(xún)方式
這篇文章主要介紹了MyBatis動(dòng)態(tài)sql查詢(xún)及多參數(shù)查詢(xún)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
Java基于JNDI 實(shí)現(xiàn)讀寫(xiě)分離的示例代碼
本文主要介紹了Java基于JNDI 實(shí)現(xiàn)讀寫(xiě)分離的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12
使用Spring?Retry實(shí)現(xiàn)業(yè)務(wù)異常重試
在系統(tǒng)中經(jīng)常遇到業(yè)務(wù)重試的邏輯,比如三方接口調(diào)用,timeout重試三遍,異常處理重試的兜底邏輯等,本文給大家介紹一下如何使用Spring?Retry優(yōu)雅的實(shí)現(xiàn)業(yè)務(wù)異常重試,需要的朋友可以參考下2024-01-01
淺談java中類(lèi)名.class, class.forName(), getClass()的區(qū)別
下面小編就為大家?guī)?lái)一篇淺談java中類(lèi)名.class, class.forName(), getClass()的區(qū)別。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05

