zoukankan      html  css  js  c++  java
  • 为什么要在项目里要用缓存

    高性能

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

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

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

    高并发

     

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

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

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

      缓存与数据库双写不一致

      缓存雪崩

      缓存穿透

      缓存并发竞争

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

  • 相关阅读:
    超级钢琴 2010年NOI
    vijos P1375 大整数(高精不熟的一定要做!)
    COGS 445. [HAOI2010]最长公共子序列
    系统升级
    mariabd mysql升级mariadb
    mysql view 视图
    mysql 杂
    mysql主从复制
    DNS迭代查询与递归查询的区别
    Python 中 str 和 repr 的区别
  • 原文地址:https://www.cnblogs.com/mengchunchen/p/10027111.html
Copyright © 2011-2022 走看看