1,什么叫缓存雪崩
由于缓存失效,大量的访问直接去访问数据库,对数据库和CPU造成巨大的压力,严重的会造成数据库的宕机,系统崩溃。
2,如何防止缓存雪崩
1,缓存雪崩造成的直接原因,是由于同一时刻大量的缓存同时失效,所以大量的访问可能都没有从缓存中获得数据,从而访问数据库了。
可以让不同的key,设置不同的缓存时间,让缓存的失效时间分布的均匀点。
缺点,开发的时候比较麻烦,你开发的这个功能,还得问别人的开发功能的缓存的失效时间
2,可以用锁
对于数据库的访问,每次只能1个线程进行访问
缺点:治标不治本,性能差,只是减少了数据库的访问压力
3,消息中间件
用消息中间件的方式,和加锁的方式比较像,消息中间间可以相当于一个缓存队列,每次访问数据库的线程相对于加锁要多一点,性能要好
4,通过一级加二级缓存的方式
一级里面查询不到,到二级里面去查询。
做二级缓存,A1为原始缓存,A2为拷贝缓存,A1失效时,可以访问A2,A1缓存失效时间设置为短期,A2设置为长期(此点为补充)
3,什么叫缓存穿透
缓存穿透就是,每次访问缓存的时候,没有访问到,然后去访问数据库,数据库也没有,多个类似的请求的时候,就会对数据库造成很大压力。
这种情况,黑客进行攻击的时候会出现
解决办法:如果数据库也没有,返回空,放入到缓存中,下次查询就不会访问数据库了,会减少数据库的压力。
private String SIGN_KEY = "${NULL}",可以将类似特别字符串作为假定的返回值。