为什么要在项目里要用缓存

高性能

  一个请求过来,数据库查询耗时600ms。但是这个结果可能接下来几个小时都不会变了,或者变了也可以不用立即反馈给用户。

  这时把结果放缓存里,一个key对应一个value,下次再有人查,不走数据库,直接从缓存里,通过一个key查出来一个value,2ms搞定。这就是所谓的高性能。  

  就是把你一些复杂操作耗时查出来的结果,如果确定后面不咋变了,然后但是马上还有很多读请求,那么直接结果放缓存,后面直接读缓存就好了。

高并发

 

  mysql单机并发请求一般建议不要超过2000/s。 所以要是你有个系统,高峰期一秒钟过来的请求有1万,那一个mysql单机绝对会死掉。

  你这个时候就只能上缓存,把很多数据放缓存,别放mysql。缓存功能简单,说白了就是key-value式操作,单机支撑的并发量轻松一秒几万十几万,支持高并发。单机承载并发量是mysql单机的几十倍。

用了缓存之后会有啥不良的后果

  缓存与数据库双写不一致

  缓存雪崩

  缓存穿透

  缓存并发竞争

转自:中华石杉Java工程师面试突击

原文地址:https://www.cnblogs.com/mengchunchen/p/10027111.html