信息发布→ 登录 注册 退出

一起来看看springboot集成redis的使用注解

发布时间:2026-01-11

点击量:
目录
  • redis简介:
  • 引入依赖:
  • 编写application.properties文件
  • 编写配置类:
  • springboot的redis注解介绍
    • (1)缓存@Cacheable
    • (2)缓存@CachePut
    • (3)缓存@CacheEvict
  • 测试
    • 基本的功能:
      • 总结

        redis简介:

        Redis是当前比较热门的NOSQL系统之一,它是一个开源的使用ANSI c语言编写的key-value存储系统
        (区别于MySQL的二维表格的形式存储。)。和Memcache类似,但很大程度补偿了Memcache的不
        足。和Memcache一样,Redis数据都是缓存在计算机内存中,不同的是,Memcache只能将数据缓存到
        内存中,无法自动定期写入硬盘,这就表示,一断电或重启,内存清空,数据丢失。所以Memcache的
        应用场景适用于缓存无需持久化的数据。而Redis不同的是它会周期性的把更新的数据写入磁盘或者把修
        改操作写入追加的记录文件,实现数据的持久化。
        Redis的特点:
        1,Redis读取的速度是110000次/s,写的速度是81000次/s;
        2,原子 。Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
        3,支持多种数据结构:string(字符串);list(列表);hash(哈希),set(集合);zset(有序集合)
        4,持久化,集群部署
        5,支持过期时间,支持事务,消息订阅
        

        引入依赖:

        <!-- redis -->
        <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <!-- spring2.X集成redis所需common-pool2-->
        <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-pool2</artifactId>
        <version>2.6.0</version>
        </dependency>
        

        编写application.properties文件

        #redi配置
        spring.redis.host=ip地址
        spring.redis.port=端口号
        spring.redis.database=0
        spring.redis.password=密码
        spring.redis.lettuce.pool.max-active=20
        spring.redis.lettuce.pool.max-wait=1
        #最大阻塞等待时间(负数表示没有限制)
        spring.redis.lettuce.pool.max-idle=5
        spring.redis.lettuce.pool.min-idle=0
        # 关闭超时时间
        spring.redis.lettuce.shutdown-timeout=100
        
        

        编写配置类:

        @EnableCaching
        @Configuration
        public class RedisConfig extends CachingConfigurerSupport {
        @Bean
        public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory
        factory) {
        RedisTemplate<String, Object> template = new RedisTemplate<>();
        RedisSerializer<String> redisSerializer = new StringRedisSerializer();
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new
        Jackson2JsonRedisSerializer(Object.class);
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        template.setConnectionFactory(factory);
        //key序列化方式
        template.setKeySerializer(redisSerializer);
        //value序列化
        template.setValueSerializer(jackson2JsonRedisSerializer);
        //value hashmap序列化
        template.setHashValueSerializer(jackson2JsonRedisSerializer);
        return template;
         }
        @Bean
        public CacheManager cacheManager(RedisConnectionFactory factory) {
        RedisSerializer<String> redisSerializer = new StringRedisSerializer();
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new
        Jackson2JsonRedisSerializer(Object.class);
        //解决查询缓存转换异常的问题
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        // 配置序列化(解决乱码的问题),过期时间600秒
        RedisCacheConfiguration config =
        RedisCacheConfiguration.defaultCacheConfig()
         .entryTtl(Duration.ofSeconds(600))
         
        .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redi
        sSerializer))
         
        .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(ja
        ckson2JsonRedisSerializer))
         .disableCachingNullValues();
        RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
         .cacheDefaults(config)
         .build();
        return cacheManager;
         }
        }
        

        springboot的redis注解介绍

        (1)缓存@Cacheable

        根据方法对其返回结果进行缓存,下次请求时,如果缓存存在,则直接读取缓存数据返回;如果缓存不存在,则执行方法,并把返回的结果存入缓存中。一般用在查询方法上。

        查看源码,属性值如下:

        (2)缓存@CachePut

        使用该注解标志的方法,每次都会执行,并将结果存入指定的缓存中。其他方法可以直接从响应的缓存中读取缓存数据,而不需要再去查询数据库。一般用在新增方法上。

        查看源码,属性值如下

        (3)缓存@CacheEvict

        使用该注解标志的方法,会清空指定的缓存。一般用在更新或者删除方法上查看源码,属性值如下

        不能连接redis:
        (1)关闭liunx防火墙
        (2)找到redis配置文件:
        修改 protected-mode yes  改为  protected-mode no
        注释掉: bind 127.0.0.1
        

        测试

        @Cacheable(value = "banner", key = "'selectIndexList'")
        @Override
        public List<CrmBanner> selectIndexList() {
        List<CrmBanner> list = baseMapper.selectList(new
        QueryWrapper<CrmBanner>().orderByDesc("sort"));
        return list;
         }
        
        @CacheEvict(value = "banner", allEntries=true)
        @Override
        public void removeBannerById(String id) {
        baseMapper.deleteById(id);
         }
        

        redis中:

        基本的功能:

        查询使用:@Cacheable注解

        修改删除:使用@CacheEvict注解

        增加:使用@CachePut注解

        总结

        本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注的更多内容!  

        在线客服
        服务热线

        服务热线

        4008888355

        微信咨询
        二维码
        返回顶部
        ×二维码

        截屏,微信识别二维码

        打开微信

        微信号已复制,请打开微信添加咨询详情!