八年開發程式設計師淺析SpringBoot 之 Shiro 與 Redis 多級快取問題

JavaDoop發表於2019-03-18

前言

來自不願意透露姓名的小師弟的投稿。這篇主要講了,專案中配置了多快取遇到的坑,以及解決辦法。

發現問題

在一次專案實踐中有實現多級快取其中有已經包括了 Shiro 的 Cache ,本以為開啟 redis 的快取是一件很簡單的事情只需要在啟動類上加上 @EnableCaching 註解就會啟動快取管理了,但是問題出現了。

重要錯誤日誌截圖

java.lang.IllegalStateException: @Bean method ShiroConfig.cacheManager called as a bean reference for type [org.apache.shiro.cache.ehcache.EhCacheManager] but overridden by non-compatible bean instance of type [org.springframework.data.redis.cache.RedisCacheManager]. Overriding bean of same name declared in: class path resource [org/springframework/boot/autoconfigure/cache/RedisCacheConfiguration.class]

錯誤日誌分析

看日誌大概就發現一個非法狀態異常,我們繼續檢視接下來的日誌有一段非常的重要日誌 Overriding bean of same name 翻譯過來的意思是幫你重寫了一個名字一樣的 Bean,我再看看日誌裡有提到 RedisCacheManager 與我自己實現的 cacheManager 到這裡我已經感覺到問題所在了,以下圖一為 RedisCacheManager 部分實現程式碼。圖二為我自己的 Shiro 的 cacheManager 實現方法。

八年開發程式設計師淺析SpringBoot 之 Shiro 與 Redis 多級快取問題

八年開發程式設計師淺析SpringBoot 之 Shiro 與 Redis 多級快取問題

解決問題 有 Spring 基礎的大家都應該還記得 Spring 不允許有相同的 Bean 出現。現在問題就在於 Redis 快取管理器和 Shiro 的快取管理器重名了,而這二者又是通過 Spring 管理,所以 Spring 讀取這二者的時候,產生衝突了。解決問題的方法很簡單:在自己實現 EhCacheManager 時把 @Bean 指定一個名字可以像這樣 @Bean(name ="ehCacheManager" ),還有其他辦法大家可以在想辦法實現一下嘿嘿。

結語

雖然我們都知道 Spring 的報錯是非常多的,但是在 Spring 的報錯日誌中查詢問題所在是非常有用的,大部分的錯誤,日誌都會給你反饋。

如果本文對你哪怕有一丁點幫助,請幫忙點好看。你的好看是我堅持寫作的動力。

相關文章