springboot整合redis缓存一些知识点
前言
最近在做智能家居平台,考虑到家居的控制需要快速的响应于是打算使用redis缓存。一方面减少数据库压力另一方面又能提高响应速度。项目中使用的技术栈基本上都是大家熟悉的springboot全家桶,在springboot2.x以后操作redis的客户端推荐使用lettuce(生菜)取代jedis。
jedis的劣势主要在于直连redis,又无法做到弹性收缩。
一、配置文件
application.yml文件中的内容
spring:
application:
name: simple-lettuce
cache:
type: redis
redis:
# 缓存超时时间ms
time-to-live:
# 是否缓存空值
cache-null-values: true
redis:
host: 127.0.0.1
port:
password:
# 连接超时时间(毫秒)
timeout:
# Redis默认情况下有16个分片,这里配置具体使用的分片,默认是0
database:
# spring2.x redis client 采用了lettuce(生菜),放弃使用jedis
lettuce:
# 关闭超时时间
shutdown-timeout:
pool:
# 连接池最大连接数(使用负值表示没有限制) 默认
max-active:
# 连接池最大阻塞等待时间(使用负值表示没有限制) 默认 -
max-wait: -
# 连接池中的最大空闲连接 默认
max-idle:
# 连接池中的最小空闲连接 默认
min-idle:
说明:
- spring.cache.type: redis
已经表明使用项目采用redis做为缓存方式。
- spring.cache.redis.cache-null-values: true
表示是否缓存空值,一般情况下是允许的。因为这涉及到缓存的三大问题:缓存穿透、缓存雪崩、缓存击穿。
如果设置false即不允许缓存空值,这样会导致很多请求数据库没有的数据时,不会缓存到redis导致每次都会请求到数据库。这种情况即:缓存穿透。
具体想初步了解这些概念可以参考文章:缓存三大问题及解决方案!
二、config配置类
@Configuration
@EnableCaching
public class RedisTemplateConfig extends CachingConfigurerSupport { private static Map<String, RedisCacheConfiguration> cacheMap = Maps.newHashMap(); @Bean(name = "stringRedisTemplate")
@ConditionalOnMissingBean(name = "stringRedisTemplate") //表示:如果容器已经有redisTemplate bean就不再注入
public StringRedisTemplate stringRedisTemplate(LettuceConnectionFactory redisConnectionFactory) {return new StringRedisTemplate(redisConnectionFactory);
} @Bean(name = "redisTemplate")
@ConditionalOnMissingBean(name = "redisTemplate")
public RedisTemplate<String, Object> redisTemplate(LettuceConnectionFactory lettuceConnectionFactory) {
System.out.println("RedisTemplateConfig.RedisTemplate");
RedisTemplate<String, Object> template = new RedisTemplate<>();
// key的序列化采用StringRedisSerializer
template.setKeySerializer(keySerializer());
template.setHashKeySerializer(keySerializer());
// value值的序列化采用fastJsonRedisSerializer
template.setValueSerializer(valueSerializer()); //使用fastjson序列化
template.setHashValueSerializer(valueSerializer()); //使用fastjson序列化
template.setConnectionFactory(lettuceConnectionFactory);
return template;
} /**
* 添加自定义缓存异常处理
* 当缓存读写异常时,忽略异常
* 参考:https://blog.csdn.net/sz85850597/article/details/89301331
*/
@Override
public CacheErrorHandler errorHandler() {
return new IgnoreCacheErrorHandler();
} @SuppressWarnings("Duplicates")
@Bean
@Primary//当有多个管理器的时候,必须使用该注解在一个管理器上注释:表示该管理器为默认的管理器
public RedisCacheManager cacheManager(RedisConnectionFactory connectionFactory) {
// 默认配置
RedisCacheConfiguration defaultCacheConfig = RedisCacheConfiguration.defaultCacheConfig()
.serializeKeysWith(keyPair())
.serializeValuesWith(valuePair())
.entryTtl(Duration.ofSeconds(DEFAULT_TTL_SECS)) //设置过期时间
.disableCachingNullValues(); // 其它配置
for(MyCaches cache : MyCaches.values()) {
cacheMap.put(cache.name(),
RedisCacheConfiguration.defaultCacheConfig()
.serializeKeysWith(keyPair())
.serializeValuesWith(valuePair())
.entryTtl(cache.getTtl())
// .disableCachingNullValues() // 表示不允许缓存空值
.disableKeyPrefix() // 不使用默认前缀
// .prefixKeysWith("mytest") // 添加自定义前缀
);
} /** 遍历MyCaches添加缓存配置*/
RedisCacheManager cacheManager = RedisCacheManager.builder(
RedisCacheWriter.nonLockingRedisCacheWriter(connectionFactory)
)
.cacheDefaults(defaultCacheConfig)
.withInitialCacheConfigurations(cacheMap)
.transactionAware()
.build(); ParserConfig.getGlobalInstance().addAccept("mypackage.db.entity.");
return cacheManager;
} /**
* key序列化方式
* @return
*/
private RedisSerializationContext.SerializationPair<String> keyPair() {
RedisSerializationContext.SerializationPair<String> keyPair =
RedisSerializationContext.SerializationPair.fromSerializer(keySerializer());
return keyPair;
} private RedisSerializer<String> keySerializer() {
return new StringRedisSerializer();
} /**
* value序列化方式
* @return
*/
private RedisSerializationContext.SerializationPair<Object> valuePair() {
RedisSerializationContext.SerializationPair<Object> valuePair =
RedisSerializationContext.SerializationPair.fromSerializer(valueSerializer());
return valuePair;
} /**
* 使用fastjson序列化
* @return
*/
private RedisSerializer<Object> valueSerializer() {
MyFastJsonRedisSerializer<Object> fastJsonRedisSerializer = new MyFastJsonRedisSerializer<>(Object.class);
return fastJsonRedisSerializer;
} @Getter
private enum MyCaches {
defaultCache(Duration.ofDays(1)),
MyCaches(Duration.ofMinutes(10)); MyCaches(Duration ttl) {
this.ttl = ttl;
}
/** 失效时间 */
private Duration ttl = Duration.ofHours(1);
}
}
说明
1. 类上的注解@EnableCaching
表明开启缓存功能。
2. extends CachingConfigurerSupport
这个类就很丰富了,其实如果没有什么特别操作也可以不用继承这个类。
这个类可以支持动态选择缓存方式,比如项目中不止一种缓存方案,有可能有ehcache那么可以自定义在什么情况下使用redis使用情况下使用ehcache。还有一些有关异常的处理。我也不是很懂具体可以参考:
3. StringRedisTemplate和RedisTemplate的使用
三、缓存注解使用
@Cacheable 使用在查询方法上
@CachePut 使用在更新、保存方法上
@CacheEvict 使用在删除方法上
需要注意的是@Cacheable、@CachePut方法一定要有返回被缓存对象。因为注解使用的AOP切面如果没有返回值表示缓存对象为空值。
@CacheConfig注解在类上,可以选择使用哪个缓存、缓存管理器、Key生成器
好了以上就是最近在项目中的一些知识点总结,如果以后使用缓存有新的体会我会同步更新的。
springboot整合redis缓存一些知识点的更多相关文章
- SpringBoot 整合 Redis缓存
在我们的日常项目开发过程中缓存是无处不在的,因为它可以极大的提高系统的访问速度,关于缓存的框架也种类繁多,今天主要介绍的是使用现在非常流行的NoSQL数据库(Redis)来实现我们的缓存需求. Spr ...
- springboot整合redis缓存
使用springBoot添加redis缓存需要在POM文件里引入 org.springframework.bootspring-boot-starter-cacheorg.springframewor ...
- SpringBoot整合redis缓存(一)
准备工作 1.Linux系统 2.安装redis(也可以安装docker,然后再docker中装redis,本文章就直接用Linux安装redis做演示) redis下载地址: 修改redis,开启远 ...
- SpringBoot缓存管理(二) 整合Redis缓存实现
SpringBoot支持的缓存组件 在SpringBoot中,数据的缓存管理存储依赖于Spring框架中cache相关的org.springframework.cache.Cache和org.spri ...
- SpringBoot入门系列(七)Spring Boot整合Redis缓存
前面介绍了Spring Boot 中的整合Mybatis并实现增删改查,.不清楚的朋友可以看看之前的文章:https://www.cnblogs.com/zhangweizhong/category/ ...
- springBoot整合redis(作缓存)
springBoot整合Redis 1,配置Redis配置类 package org.redislearn.configuration; import java.lang.reflect.Method ...
- SpringBoot整合Redis、mybatis实战,封装RedisUtils工具类,redis缓存mybatis数据 附源码
创建SpringBoot项目 在线创建方式 网址:https://start.spring.io/ 然后创建Controller.Mapper.Service包 SpringBoot整合Redis 引 ...
- Redis-基本概念、java操作redis、springboot整合redis,分布式缓存,分布式session管理等
NoSQL的引言 Redis数据库相关指令 Redis持久化相关机制 SpringBoot操作Redis Redis分布式缓存实现 Resis中主从复制架构和哨兵机制 Redis集群搭建 Redis实 ...
- SpringBoot整合Redis、ApachSolr和SpringSession
SpringBoot整合Redis.ApachSolr和SpringSession 一.简介 SpringBoot自从问世以来,以其方便的配置受到了广大开发者的青睐.它提供了各种starter简化很多 ...
随机推荐
- Vue-cli项目结构讲解
|-- build // 项目构建(webpack)相关代码 | |-- build.js // 生产环境构建代码 | |-- check-version.js // 检查node.npm等版本 | ...
- 深入Resource实现多语言支持的应用详解
首先为假设有一个应用程序CAStudy,接着右键添加一个资源文件Resource1.resx. Resource1.resx里面如下: Main函数如下:static void Main(){ ...
- ckpt pb
(t20190518) luo@luo-All-Series:/dev/disk_2019/mask_rcnn_20190518/Mask_RCNN_20190902/models/research$ ...
- Spring cloud微服务安全实战-6-7jwt改造总结
限流的改造. 同样注意,不要声明成Spring的Bean 在上面声明Rateliiter 如果能获取到权限继续往下走,没权限就返回,to many request的错误信息. 加到过滤器链上 加载Sp ...
- 【429】关于ADT的访问权限
在看老师代码的时候,发现ADT中的 struct 有时候写到了 adt.c 里面,有时候写到了 adt.h 里面,其实有些困惑,经过仔细研究,发现写在 adt.h 中的 struct 可以在 test ...
- BASH输出着色显示
通过将其输出着色,可以使BASH脚本更漂亮.使用ANSI转义序列设置文本属性,例如前景色和背景色. 使用以下模板格式来编写彩色文本: echo -e "\e[前景色值;背景色值;2m文本\e ...
- websockify文档
一.官网地址 地址:https://github.com/novnc/websockify 二.开启代理 1.单台服务器 python /usr/local/websockify/websockify ...
- Deepin安装前分区总结
linux的分区的概念应该这么理解,为某个目录创建/挂载分区,比如为/home创建/挂载到某个分区上: 1.需要/boot分区,1.5G: 2./分区,100G:[会自动创建其他目录如/srv,/ro ...
- [HTTPS] - 请求API失败(Could not create SSL/TLS secure channel)之解决
背景 在单元测试中请求 HTTPS API 失败. 异常 Result StackTrace: at System.Web.Services.Protocols.WebClientProtocol. ...
- [DevExpress] - 使得 XtraEditors.TextEdit 失去焦点(LostFocus)的方法
场景 WinForm 应用,使用了 DevExpress.XtraEditors.TextEdit 控件的 KeyPress 和 Leave 事件.期望在 TextEdit 上按下回车键或者当 Tex ...