springboot整合redis实现缓存

使用redis做缓存整合起来并不难,在整合的时候一定要将show sql打开,这样才能测试你写整合的redis缓存是否成功了。首先,你需要在官网下载一个redis,然后启动redis-server,默认端口是6379,启动后的界面如下:

redis在springboot的maven依赖:

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-data-redis</artifactId>
	<version>1.5.2.RELEASE</version>
</dependency>

在application.yml添加配置信息,其中cache_name是自定义的缓存名字,可以定义多个

spring: 
  redis:
    ##默认redis客户端连接为0 可修改
    database: 0
    host: 127.0.0.1
    port: 6379
    cache_name: XiChuanRedis
    ##password:
    pool:
      ##连接池最大空闲连接
      max-idle: 8
      min-idle: 0
      max-active: 8
      max-wait: 1
    timeout: 5000

新建一个redis的配置文件RedisConfig

@Configuration
@EnableCaching//启用缓存
public class RedisConfig extends CachingConfigurerSupport{

    @Value("${spring.redis.cache_name}")
    private String cacheName;

    @SuppressWarnings("rawtypes")
    @Bean
    public CacheManager cacheManager(RedisTemplate redisTemplate) {
        RedisCacheManager rcm = new RedisCacheManager(redisTemplate);
        // 多个缓存的名称,目前只定义了一个
        rcm.setCacheNames(Arrays.asList(cacheName));
        //设置缓存过期时间(秒)
        rcm.setDefaultExpiration(6000);
        return rcm;
    }

    @Bean
    public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {
        StringRedisTemplate template = new StringRedisTemplate(factory);
        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.setValueSerializer(jackson2JsonRedisSerializer);
        template.afterPropertiesSet();
        return template;
    }
}

配置完成后,就可以在代码中使用@Cacheable、@CachePut、@CacheEvict。这三个注解必须写在方法上,才能生效.示例如下:

@Component
public classBaseServiceImpl{

    @Autowired
    ParamRepository paramRepository;

    @Cacheable(value="XiChuanRedis", key="'sign_test'")  
    public String getNotFinishedTypeCode(){
        List<Param> params = paramRepository.findBySpiderOver(0);

        if(params != null && params.size() > 0){
            return  params.stream()   //先将List按照id进行排序,然后取出最上面的那个,然后取出第一个
                    .sorted(Comparator.comparing(HeiGuangParam::getId))
                    .collect(Collectors.toList())
                    .get(0)
                    .getTypeCode();
        }else{   //如果没有就返回null
            return null;
        }
    }

    /**
     * 更新param后,需要将redis中的值移除
     * @param param
     */
    @CacheEvict(value="XiChuanRedis", key="'sign_test'")
    public void updateParamByTypeCode(Param param){
        paramRepository.save(param);
    }
}
 

@Cacheable:如果redis在相同的Cache有相同的key的缓存元素时,就会直接在redis缓存中,根据key读取缓存并返回结果;如果没有,则先调用方法,将返回值写入到redis缓存中,然后返回结果。它的属性有:value、key、condition

value:指定是哪一个Cache,可以指定多个Cache。例如:@Cacheable({"cache1", "cache2"})

key:缓存的key,当在清楚缓存时要与此对应。

1.key为null,则使用默认key。

2.key为一个字符串,例如:@CacheEvict(value="XiChuanRedis", key="'department_code_'")。
3.key为方法中的一个方法上的一个属性,例如:

@CacheEvict(value="XiChuanRedis", key="'code_'+#departmentCode")
public String getNameByCode(String departmentCode){
}

4.key为方法中的一个方法上的一个实体的属性,例如:

@Cacheable(value="XiChuanRedis", key="'userid_'+#user.id")
public User getUserById(Integer id){
}

condition:缓存条件,可以直接为null,例子如下:

​​​​​​​@Cacheable(value="XiChuanRedis", key="'userid_'+#user.id", condition="#user.id%2==0")
public User getUserById(Integer id){
}

@CachePut:它会每次调用方法,然后将缓存写到redis缓存中,并将结果返回。与@Cacheable不同的是,它不会检测在相同Cache中是否存在相同key的缓存元素。

value:与@Cacheable一致

key:与@Cacheable一致

condition:与@Cacheable一致

@CacheEvict:根据Cache与key清空缓存。

value:与@Cacheable一致

key:与@Cacheable一致

condition:与@Cacheable一致

allEntries:是否清空所有缓存,默认为false。例如:@CacheEvict(value="XiChuanRedis", key="'code'",allEntries=true)

beforeInvocation:是否在方法执行前就清空缓存,默认为false。例如:@CacheEvict(value="XiChuanRedis", key="'code'",beforeInvocation=true)

 github上有我更多的笔记:Raray-chuan (兮川) · GitHub,欢迎stars与following,如果有问题可以在issue中向我咨询

关注我的公众号,获取更多关于后端、大数据的知识

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值