对缓存穿透、缓存并发和缓存雪崩的一些理解
2018-08-26 17:19:08来源:博客园 阅读 ()
有没有遇到了击穿缓存层,好几个线程访问数据库。导致程序奔溃的事?
一直想过来总结下,总是拖着,今天就给整写了。
定义:
缓存穿透通常是带空key值,恶意攻击,欺骗缓存造成无限制访问数据库;
缓存并发通常是缓存key过期时,多请求查询数据库,回写缓存,导致性能降低
缓存雪崩通常缓存服务器重启或者大量缓存集中失效,致使数据库访问加大,甚至压垮数据库。
解决:
缓存穿透:可以对输入的参数进行过滤,把无效请求拦在外面。具体比如判断ID是否合法。
缓存并发:加锁。分布式锁,本地锁,软过期。这三种都可以。首推软过期。
缓存雪崩:通常的解决办法是对不同的数据使用不同的失效时间,就会避免缓存雪崩。
讲的是个大概的思路具体的解决办法网上都有代码可查。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- redis缓存 2020-06-12
- MyBatis缓存特性详解 2020-06-03
- 那些面试官必问的JAVA多线程和并发面试题及回答 2020-05-28
- 架构设计 | 缓存管理模式,监控和内存回收策略 2020-05-26
- 【JavaSE】多线程与并发编程(总结) 2020-05-25
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash