redis 缓存穿透

1、在高并发的场景下本应该查询缓存的,都去查询数据库了

情况1例如:

if (!map.isEmpty()) {
   // 将查询结果放入缓存。
   redisClientTemplate.set("testfuncid",(Serializable) map,-1);
   remap = map;
} else {
   logger.error("Exception->AreaRegonServiceImpl-->getAreaRegonMap-->map is null");
}

此种情况下在高并发的情况下,多个进程会同时访问数据库并向redis放数据

情况1解决的办法是添加关键字

  1、synchronized (效率太低了)

      2、双重检测的添加

    String userFuncMapKey = ConstantConfig.USER_FUNC_MAP_KEY;
      // 获取缓存
      Map<String, List> remap = (Map<String, List>)redisClientTemplate.get("testfuncid");
      // 若缓存为空,则查询DB
      if (remap == null || remap.isEmpty()) {
         synchronized (this){
            remap = (Map<String, List>)redisClientTemplate.get("testfuncid");(最最关键的就是这一步)
            if(remap == null || remap.isEmpty()){
               System.out.println( "重数据库里面获得");

 

 

2、是指查询一个数据库一定不存在的数据,这样就可以绕过缓存直接访问数据库,如此进行攻击的话,就造成数据库的压力过大。

 

解决的方案:查询不到的数据也放到redis里面,设置有效时间是60秒

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值