系统教程 · 2023年8月11日

Spring Boot集成Redis常用注解有哪些?

Spring Boot集成Redis常用注解有哪些?

收藏

小伙伴们有没有觉得学习数据库很有意思?有意思就对了!今天就给大家带来《Spring Boot集成Redis常用注解有哪些?》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

    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,支持过期时间,支持事务,消息订阅

    引入依赖:

       
    
       
        
         org.springframework.boot
        
        
         spring-boot-starter-data-redis
        
       
       
       
        
         org.apache.commons
        
        
         commons-pool2
        
        
         2.6.0
        
       

    编写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
       
         redisTemplate(RedisConnectionFactory
    factory) {
    RedisTemplate
        
          template = new RedisTemplate(); RedisSerializer
         
           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
          
            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
       
         selectIndexList() {
    List
        
          list = baseMapper.selectList(new QueryWrapper
         
          ().orderByDesc("sort")); return list;  } @CacheEvict(value = "banner", allEntries=true) @Override public void removeBannerById(String id) { baseMapper.deleteById(id);  }
         
        
       

    redis中:

    基本的功能:

    查询使用:@Cacheable注解

    修改删除:使用@CacheEvict注解

    增加:使用@CachePut注解