zoukankan      html  css  js  c++  java
  • 缓存雪崩 缓存穿透

    1,什么叫缓存雪崩

         由于缓存失效,大量的访问直接去访问数据库,对数据库和CPU造成巨大的压力,严重的会造成数据库的宕机,系统崩溃。

    2,如何防止缓存雪崩

         1,缓存雪崩造成的直接原因,是由于同一时刻大量的缓存同时失效,所以大量的访问可能都没有从缓存中获得数据,从而访问数据库了。

               可以让不同的key,设置不同的缓存时间,让缓存的失效时间分布的均匀点。

               缺点,开发的时候比较麻烦,你开发的这个功能,还得问别人的开发功能的缓存的失效时间

          2,可以用锁

               对于数据库的访问,每次只能1个线程进行访问

               缺点:治标不治本,性能差,只是减少了数据库的访问压力

           3,消息中间件

               用消息中间件的方式,和加锁的方式比较像,消息中间间可以相当于一个缓存队列,每次访问数据库的线程相对于加锁要多一点,性能要好

           4,通过一级加二级缓存的方式

                一级里面查询不到,到二级里面去查询。

               做二级缓存,A1为原始缓存,A2为拷贝缓存,A1失效时,可以访问A2,A1缓存失效时间设置为短期,A2设置为长期(此点为补充)

    3,什么叫缓存穿透

         缓存穿透就是,每次访问缓存的时候,没有访问到,然后去访问数据库,数据库也没有,多个类似的请求的时候,就会对数据库造成很大压力。

         这种情况,黑客进行攻击的时候会出现

         解决办法:如果数据库也没有,返回空,放入到缓存中,下次查询就不会访问数据库了,会减少数据库的压力。

         private String SIGN_KEY = "${NULL}",可以将类似特别字符串作为假定的返回值。

  • 相关阅读:
    SIP语音对讲从零到整之(二)resiprocate编译(Linux,库用于Android)
    Intel Media SDK decode_sample剖析(一)——初始化及解码数据头
    Hadoop-HA集群搭建-rehl7.4
    (1)jmeter录制脚本(使用代理的方式)
    Java自动化环境搭建笔记(3)
    Java自动化环境搭建笔记(1)
    ant安装(Windows)
    jmeter源码环境(IDEA)
    离线安装docker(RedHat7.4)
    PostgreSQL日志分析工具
  • 原文地址:https://www.cnblogs.com/pickKnow/p/11314726.html
Copyright © 2011-2022 走看看