防止缓存击穿

时间:2022-10-25 20:54:36
public Long querySumJe() {
        String sJe = redisDao.getValue("sumje");
        if(!"null".equalsIgnoreCase(sJe) && sJe != null){
            System.out.println("==========cache");
            return Long.parseLong(sJe);
        }else{
            synchronized (this) {
                sJe = redisDao.getValue("sumje");
                if(!"null".equalsIgnoreCase(sJe) && sJe != null){
                    System.out.println("==========cache2");
                    return Long.parseLong(sJe);
                }
                System.out.println("==========db");
                Long je = chjlmxbMapper.querySumJe();
                redisDao.putValue("sumje", je+"");
                return je;
            }
        }
    }

 

注意:一般的在锁里面不会再查询缓存了,这样就一样会造成缓存击穿,所以在锁中查询数据库前再查询一次缓存是必要的,需要注意。