使用SpringCache实现Redis缓存

目录

一 什么是Spring Cache

二 Spring Cache 各注解作用

        ①EnableCaching

        ②Cacheable

        ③CachePut

        ④CacheEvict

三实现步骤

①导入spring cache依赖和Redis依赖

②配置Redis连接信息

③在启动类上加上开启spring cache的注解 

④ 在对应的方法上加上需要的注解


一 什么是Spring Cache

        spring cache是一个框架,实现了基于注解的缓存功能,只需要简单的加一个注解,就能实现缓存功能。

        而且spring cache提供了多种缓存的实现,例如:

        ①EHCahe

        ②Caffeine

        ③Redis

        想用那种缓存只需要导入对应的jar包即可。

        本次我们使用Redis缓存作为用例。

二 Spring Cache 各注解作用

        ①EnableCaching

                开启缓存注解功能 , 通常加在启动类上。

        ②Cacheable

在执行方法前先查询缓存中是否有数据,如果有数据,则直接返回缓存数据;如果没有数据,则调用方法并将方法返回值放到缓存中。

        ③CachePut

将方法返回值放到缓存中

        ④CacheEvict

将一条或者多条数据从缓存中删除

三实现步骤

①导入spring cache依赖和Redis依赖

<!--        spring cache缓存-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-cache</artifactId>
        </dependency>
<!--        使用redis缓存-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

②配置Redis连接信息

 这是在yml文件中配置的

③在启动类上加上开启spring cache的注解 

@SpringBootApplication
@MapperScan("com.fs.mapper")
@Slf4j
@EnableCaching  //开启springCache缓存
public class user_managementApplication {
    public static void main(String[] args) {

        SpringApplication.run(user_managementApplication.class , args);
        log.info("server is start...");

    }
}

④ 在对应的方法上加上需要的注解

        例如:我在下面这个新增用户的方法上,需要把返回的用户存入缓存中去

    @PutMapping("/add")
    @CachePut(cacheNames = "userCache" , key = "#user.uid")  //比如uid为3 ,那么得到存入redis的可以为:“userCache::3”
    public Result addUser(@RequestBody User user){
        log.info("进入新增用户:{}",user);
        userService.addUser(user) ;
        return Result.success() ;
    }

这里需要注意一点,因为我这个方法并没有返回用户对象,返回的是一个Result , 所以存储的也只是一个Result。

另外,这个uid是主键回显的,因为我这里插入使用的mp自带的,所以mp会自己帮我把id回显,我只需要从user中获取就行了,如果你是用mybatis自己写的sql语句,那么你需要自己设置主键回显,可以在mapper接口层使用如下注解:

    @Options(useGeneratedKeys = true , keyProperty = "id") //把主键id映射到“id”返回
    @Update("update tb_user set is_can_login=0 where  uid=#{uid}")
    void updateStatueByUid(Integer uid);

最后我们可以看见数据成功缓存到了redis,并且key也是我们设置好的。

其他还有很多注解,这里就不一一做示范了,根据自己的需要使用不同注解即可。 

  • 13
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用SpringCacheRedis可以很方便地实现数据缓存,下面是具体的步骤: 1. 配置Redis 首先需要在项目中引入Redis相关的依赖,如下: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 然后在application.properties文件中配置Redis的连接信息,如下: ```properties spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.password=123456 ``` 2. 配置SpringCacheSpringBoot中,可以使用@Cacheable、@CachePut、@CacheEvict等注解来实现缓存,但是需要配置一个CacheManager来管理缓存。可以使用RedisCacheManager来管理Redis缓存,如下: ```java @Configuration @EnableCaching public class CacheConfig extends CachingConfigurerSupport { @Bean public RedisConnectionFactory redisConnectionFactory() { JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory(); jedisConnectionFactory.setHostName("127.0.0.1"); jedisConnectionFactory.setPort(6379); jedisConnectionFactory.setPassword("123456"); return jedisConnectionFactory; } @Bean public RedisTemplate<String, Object> redisTemplate() { RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); redisTemplate.setConnectionFactory(redisConnectionFactory()); redisTemplate.setDefaultSerializer(new StringRedisSerializer()); redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer()); return redisTemplate; } @Bean public CacheManager cacheManager() { RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig() .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer())) .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer())); RedisCacheManager redisCacheManager = RedisCacheManager.builder(redisConnectionFactory()) .cacheDefaults(redisCacheConfiguration) .transactionAware() .build(); return redisCacheManager; } } ``` 其中,redisConnectionFactory方法是用来创建Redis连接的,redisTemplate方法是用来进行Redis操作的,cacheManager方法是用来创建RedisCacheManager的。 3. 使用缓存 有了上面的配置之后,就可以在项目中使用缓存了。例如,我们可以对一个方法进行缓存,如下: ```java @Service public class UserService { @Autowired private UserRepository userRepository; @Cacheable(value = "userCache", key = "#id") public User getUserById(Long id) { System.out.println("getUserById from DB"); return userRepository.findById(id).orElse(null); } } ``` 在这个例子中,我们使用了@Cacheable注解将getUserById方法进行了缓存,value属性表示缓存的名称,key属性表示缓存的键值。如果缓存中已经有了对应的数据,则直接从缓存中获取数据,否则就从数据库中获取数据,并将数据加入到缓存中。 4. 清除缓存 有时候需要从缓存中清除某些数据,可以使用@CacheEvict注解来实现,如下: ```java @Service public class UserService { @Autowired private UserRepository userRepository; @Cacheable(value = "userCache", key = "#id") public User getUserById(Long id) { System.out.println("getUserById from DB"); return userRepository.findById(id).orElse(null); } @CacheEvict(value = "userCache", key = "#id") public void deleteUserById(Long id) { userRepository.deleteById(id); } } ``` 在这个例子中,我们使用了@CacheEvict注解将deleteUserById方法进行了缓存清除,value属性表示缓存的名称,key属性表示缓存的键值。如果有对应的数据,则从缓存中清除该数据。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值