javascript
如果redis哨兵宕机了怎么办_Spring集成Redis做缓存,Redis宕机时Spring处理的问题
采用的是Spring自帶的緩存管理,使用Redis做緩存,在Spring中配置如下
@Configuration
@EnableCaching
public class CachingConfig {
@Bean
public CacheManager cacheManager(RedisTemplate redisTemplate) {
return new RedisCacheManager(redisTemplate);
}
@Bean
public JedisConnectionFactory jedisConnectionFactory() {
JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory();
jedisConnectionFactory.afterPropertiesSet();
return jedisConnectionFactory;
}
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(redisConnectionFactory);
redisTemplate.afterPropertiesSet();
return redisTemplate;
}
}
在DAO實現中使用緩存的代碼如下
@Cacheable(value = "userCache", key = "'id_'+#id")
public User selectUser(String id) {
return getMapper().selectUser(id);
}
這里使用的是單個Redis,在Redis正常工作時沒有問題,但是如果這時候Redis掛掉了,訪問時就會拋出獲取與Redis之間connection異常(這也正常,Redis都掛掉了)。
跟了一下代碼,發現此時Spring的處理邏輯是這樣的:
配置有緩存-->先去Redis找-->連接不上-->拋出錯誤
但是我理解和問題的是:
緩存如果掛掉了,請求應該就直接去數據庫取,否則緩存一掛豈不是整個系統都不可用了?
Spring中是否有什么配置使緩存能否做到可插拔?
實際中會直接使用這種方案嗎?還是使用Redis集群方案(抱歉這個還沒研究)?
實際項目中自己實現緩存管理方案?還是其他的好的解決方案?
謝謝!
總結
以上是生活随笔為你收集整理的如果redis哨兵宕机了怎么办_Spring集成Redis做缓存,Redis宕机时Spring处理的问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: cap流程图_源码阅读笔记 BiLSTM
- 下一篇: 前缀表达式后缀表达式_五分钟小知识之什么