防止缓存击穿

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;
            }
        }
    }

 

注意:通常的在锁里面不会再查询缓存了,这样就同样会形成缓存击穿,因此在锁中查询数据库前再查询一次缓存是必要的,须要注意。redis

相关文章
相关标签/搜索