缓存雪崩 缓存穿透

1,什么叫缓存雪崩

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

2,如何防止缓存雪崩

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

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

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

      2,可以用锁

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

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

       3,消息中间件

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

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

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

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

3,什么叫缓存穿透

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

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

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

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

猜你喜欢

转载自www.cnblogs.com/pickKnow/p/11314726.html