SpringBoot实现redis缓存菜单列表
因为系统的菜单列表是不轻易改变的,所以不需要在每次请求的时候都去查询数据库,所以,在第一次根据用户id请求到菜单列表的时候,可以把菜单列表的数据缓存在redis里,在第二次请求菜单列表的时候,可以直接在redis缓存里面获取数据,从而减少对数据库的操作,提升性能!首先,我们要下载redis到本地,然后在cmd终端打开redis的src目录,然后运行redis-server即可开启redis本地服务(mac),开启了redis服务后,就要在项目中配置相关的redis的代码了,首先在pom.xml中导入我们需要的包:
org.springframework.boot spring-boot-starter-data-redis2.5.1 org.apache.commons commons-pool22.9.0
然后在config文件下创建ReidsConfig配置类文件:
/** * redis配置类 */@Configurationpublic class RedisConfig {@Beanpublic RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory){RedisTemplate redisTemplate=new RedisTemplate<>(); //String类型key序列器redisTemplate.setKeySerializer(new StringRedisSerializer()); //String类型value序列器redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer()); //Hash类型key序列器redisTemplate.setHashKeySerializer(new StringRedisSerializer()); //Hash类型value序列器redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer()); redisTemplate.setConnectionFactory(redisConnectionFactory); return redisTemplate; }}
这个配置文件主要是对String类型和hash类型的key和value做序列化操作;
接下来就是使用redis了,在我们需要引入redis的根据用户id获取菜单列表接口的实现类中,判断下,如果菜单已经缓存在了redis中,则从redis中获取数据返回,否则去查询数据库获取数据:
/** * 【SpringBoot实现redis缓存菜单列表】 * 菜单表 服务实现类 *
* * @author hhk * @since 2022-01-04 */@Servicepublic class MenuServiceImpl extends ServiceImplimplements IMenuService {@Autowiredprivate MenuMapper menuMapper; @Autowiredprivate RedisTemplate redisTemplate; /*** 根据用户id查询菜单列表* @return*/@Overridepublic List
到这里,重启项目即可测试接入缓存是否成功了!!!
到此这篇关于SpringBoot实现redis缓存菜单列表的文章就介绍到这了,更多相关SpringBoot redis缓存菜单列表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- netty系列之:channel|netty系列之:channel,ServerChannel和netty中的实现
- java|springboot缓存+springboot整合redis缓存
- springboot|springboot配置redis缓存数据库查询
- Spring|SpringBoot整合Redis实现缓存(自动缓存 + 手动aop缓存)
- java|SpringBoot整合Redis以及Redis缓存
- 通过Dapr实现一个简单的基于.net的微服务电商系统(二十)——Saga框架实现思路分享
- .NET|.NET Core使用flyfire.CustomSerialPort实现Windows/Linux跨平台串口通讯
- MySQL百万级数据大分页查询优化的实现
- 自己动手用Springboot实现仿百度网盘的实践
- SpringBoot重点详解|SpringBoot重点详解--使用MongoDB