SpringBoot 啟動(dòng)報(bào)錯(cuò)Unable to connect to Redis server: 127.0.0.1/127.0.0.1:6379問題的解決方案
問題描述
使用開源項(xiàng)目 youlai-boot 中,使用默認(rèn)線上配置沒問題的,但將 Redis 的修改為本地的環(huán)境出現(xiàn)無法連接的錯(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ù)沒有密碼,因此我們理所當(dāng)然地將 password
的值留空。然而,這正是問題的根本原因,因?yàn)榭罩等詴?huì)被解析為一個(gè)空字符串,而不是被忽略。
如果只是這樣說是沒有說服力的,接下來我將本著“源碼面前無秘密”的原則,深入揭示問題的本質(zhì)。
源碼分析
假設(shè)本地的 Redis 未配置密碼,SpringBoot 的 Redis 連接配置如下:
spring: data: redis: database: 0 host: 127.0.0.1 port: 6379 password:
MasterSlaveConnectionManager#createClient
根據(jù)配置創(chuàng)建客戶端,其中配置的 password 是空字符串而不是null。
BaseConnectionHandler#channelActive
方法根據(jù)配置進(jìn)行 Redis 客戶端連接初始化。由于配置中的 password 被解析成空字符串而非 null,因此嘗試使用空字符串作為密碼連接 Redis,但由于 Redis 服務(wù)未設(shè)置密碼,連接失敗。
解決方案
由上可知,如果將配置的 password 值設(shè)置為空,則客戶端在連接時(shí)會(huì)使用空字符串作為密碼進(jìn)行認(rèn)證。由于服務(wù)端未設(shè)置密碼,因此連接失敗。
解決方法其實(shí)很簡單,如果 Redis 服務(wù)未設(shè)置密碼,需要將 password 注釋或刪除,而不是設(shè)置為空字符串。
spring: data: redis: database: 0 host: 127.0.0.1 port: 6379 # 如果 Redis 服務(wù)未設(shè)置密碼,需要將 password 刪除或注釋,而不是設(shè)置為空字符串 # password:
再次調(diào)試可以看到 password 為 null ,直接跳過密碼認(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問題的解決方案的詳細(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ò)誤:找不到或無法加載主類的三種解決方法
- 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-12Mybatis中自定義實(shí)例化SqlSessionFactoryBean問題
這篇文章主要介紹了Mybatis中自定義實(shí)例化SqlSessionFactoryBean問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02MyBatis動(dòng)態(tài)sql查詢及多參數(shù)查詢方式
這篇文章主要介紹了MyBatis動(dòng)態(tài)sql查詢及多參數(shù)查詢方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10Java基于JNDI 實(shí)現(xiàn)讀寫分離的示例代碼
本文主要介紹了Java基于JNDI 實(shí)現(xiàn)讀寫分離的示例代碼,文中通過示例代碼介紹的非常詳細(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中類名.class, class.forName(), getClass()的區(qū)別
下面小編就為大家?guī)硪黄獪\談java中類名.class, class.forName(), getClass()的區(qū)別。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05