Redis缓存读写

实现读写代码

@Configuration
@Aspect
public class RedisAop {
    @Autowired
    private RedisTemplate redisTemplate;
    /**
     * 添加缓存
     */
    @Around("@annotation(com.baizhi.config.AddCacheAnnotation)")
    public Object addCache(ProceedingJoinPoint joinPoint) throws Throwable {
//        1.获取key 和 hashKey(方法名)
        String key = joinPoint.getTarget().getClass().getName();
        System.out.println("key: "+key);

//        Signature 方法签名对象(就是方法名的对象) 字符串是不可变的 直接拼接会生成中间对象
        StringBuffer buffer = new StringBuffer();
        buffer.append(joinPoint.getSignature().getName());
        Object[] args = joinPoint.getArgs();
        for (Object arg : args) {
            buffer.append(arg);
        }
        String hashKey = buffer.toString();
        System.out.println("hashKey: "+hashKey);

//        2.通过 key 和 hashKey 查询Redis
        HashOperations hashOperations = redisTemplate.opsForHash();
        Object result = hashOperations.get(key, hashKey);

//        3.如果没有数据 查询数据库 放行操作
        if (result == null){
            System.out.println("查询数据");
//            3.1 查询数据库
            result = joinPoint.proceed();

//            3.2 重建缓存
            Map map = new HashMap();
            map.put(hashKey,result);
            hashOperations.putAll(key,map);

//            3.3 设置过期时间 缓存的数据都是不安全的
            redisTemplate.expire(key,100, TimeUnit.SECONDS);
        }else {
            System.out.println("查询缓存");
        }

        return result;
    }
    /**
     * 删除缓存
     * 切入点 切注解
     *
     * JoinPoint 切入点 连接点 对象  可以获取目标方法和对象所有的数据【反射】
     *
     * aspectj 实现了注解式
     *
     * this super
     */
    @Before("@annotation(com.baizhi.config.DeleteCacheAnnotation)")
    public void deleteCache(JoinPoint joinPoint){
//        key 获取目标方法的类名
        String key = joinPoint.getTarget().getClass().getName();
//        删除
        redisTemplate.delete(key);
    }
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis缓存是一种常用的缓存技术,可以提高系统的性能和响应速度。下面是Redis缓存的实现方式: 1. 安装和配置Redis:首先需要在服务器上安装Redis,并进行相关的配置。可以从Redis官网下载安装包,然后按照官方文档进行配置。 2. 连接Redis:在应用程序中,需要使用Redis客户端库来连接和操作Redis服务器。常用的客户端库有Jedis(Java)、StackExchange.Redis(C#)、redis-py(Python)等。 3. 缓存数据:将需要缓存的数据存储到Redis中。可以使用Redis的字符串、哈希表、列表、集合等数据结构来存储不同类型的数据。 4. 设置缓存过期时间:可以为缓存数据设置过期时间,以控制缓存的有效期。当缓存数据过期后,系统会重新从数据源获取最新数据并更新缓存。 5. 缓存读写操作:在应用程序中,通过调用Redis客户端库提供的API来进行缓存读写操作。读取缓存时,先检查缓存中是否存在需要的数据,如果存在则直接返回;如果不存在,则从数据源获取数据,并将数据存储到缓存中。 6. 缓存更新策略:根据业务需求,可以采用不同的缓存更新策略。常见的策略有定时刷新、缓存失效时更新、手动更新等。 7. 缓存穿透和雪崩处理:为了防止缓存穿透(即查询不存在的数据导致频繁访问数据库)和缓存雪崩(即大量缓存同时失效导致数据库压力过大),可以采用一些技术手段,如布隆过滤器、热点数据预加载、多级缓存等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值